禁用使用F5按键刷新,兼容chrome、firefox、IE浏览器

有时不想让用户按F5一直刷新页面,可以通过下面的代码来实现,由于浏览器的兼容问题,下面给出低版本按键事件和高版本按键事件代码:

低版本按键事件

window.onload = function(){
    var timer = null; //声明定时器变量
    document.onkeydown = function(event){
        clearTimeout(timer); //每次按键先清除定时器,避免定时器重复多开
        var event = event || window.event;
        var keycode = event.keyCode || event.which;
        if(keycode == 116){
            alert('触发F5按键');
            if(event.preventDefault){ //chrome、firefox、IE9+
                event.preventDefault(); 
            }else{//IE8-
                event.keyCode = 0;
                event.returnValue = false;
            }
            timer = setTimeout(function(){ //设置一个定时器,3秒后清除按键事件,恢复按F5刷新功能
                alert('恢复刷新');
                document.onkeydown = null;
            }, 3000);
        }
    };
};

高版本按键事件

window.onload = function(){    var timer = null;    if(document.addEventListener){//chrome、firefox、IE9+
        document.addEventListener('keydown',shieldRefresh);
    }else{//IE8-
        document.attachEvent('onkeydown',shieldRefresh);
    }

    function disableRefresh(event){
        clearTimeout(timer);        var event = event || window.event;        var keycode = event.keyCode || event.which;        if(keycode == 116){
            alert('触发F5按键');            if(event.preventDefault){//chrome、firefox、IE9+
                event.preventDefault();
            }else{//IE8-
                event.keyCode = 0;                event.returnValue = false;
            }
            timer = setTimeout(function(){
                alert('恢复刷新');                if(document.removeEventListener){
                    document.removeEventListener('keydown',shieldRefresh);
                }else{
                    document.detachEvent('onkeydown',shieldRefresh);
                }
            }, 3000);
        }
    }
};

欢迎分享本文,转载请保留出处:前端ABC » 禁用使用F5按键刷新,兼容chrome、firefox、IE浏览器

分享到:更多 ()

发表评论 0