JS禁止浏览器后退键

当键盘敲下后退键(Backspace)后  

1、禁止浏览器自动后退

 2、但不影响密码、单行文本、多行文本输入框等的回退操作 

//方法一:
////当键盘敲下后退键(Backspace)后 
//1、禁止浏览器自动后退 
//2、但不影响密码、单行文本、多行文本输入框等的回退操作
//window.onload = function () {
//    /**************************** 
//     * 作者:q821424508@sina.com   * 
//     * 时间:2012-08-20            * 
//     * version:2.1              * 
//     *                          * 
//     ****************************/
//    document.getElementsByTagName("body")[0].onkeydown = function () {

//        //获取事件对象  
//        var elem = event.relatedTarget || event.srcElement || event.target || event.currentTarget;

//        if (event.keyCode == 8) {//判断按键为backSpace键  

//            //获取按键按下时光标做指向的element  
//            var elem = event.srcElement || event.currentTarget;

//            //判断是否需要阻止按下键盘的事件默认传递  
//            var name = elem.nodeName;

//            if (name != 'INPUT' && name != 'TEXTAREA') {
//                return _stopIt(event);
//            }
//            var type_e = elem.type.toUpperCase();
//            if (name == 'INPUT' && (type_e != 'TEXT' && type_e != 'TEXTAREA' && type_e != 'PASSWORD' && type_e != 'FILE')) {
//                return _stopIt(event);
//            }
//            if (name == 'INPUT' && (elem.readOnly == true || elem.disabled == true)) {
//                return _stopIt(event);
//            }
//        }
//    }
//}


//function _stopIt(e) {
//    if (e.returnValue) {
//        e.returnValue = false;
//    }
//    if (e.preventDefault) {
//        e.preventDefault();
//    }

//    return false;
//}


//方法二:
////当键盘敲下后退键(Backspace)后 
//1、禁止浏览器自动后退 
//2、但不影响密码、单行文本、多行文本输入框等的回退操作

//处理键盘事件 禁止后退键(Backspace)密码或单行、多行文本框除外 
//function banBackSpace(e) {
//    var ev = e || window.event;//获取event对象 
//    var obj = ev.target || ev.srcElement;//获取事件源 

//    var t = obj.type || obj.getAttribute('type');//获取事件源类型 

//    //获取作为判断条件的事件类型 
//    var vReadOnly = obj.getAttribute('readonly');
//    var vEnabled = obj.getAttribute('enabled');
//    //处理null值情况 
//    vReadOnly = (vReadOnly == null) ? false : vReadOnly;
//    vEnabled = (vEnabled == null) ? true : vEnabled;

//    //当敲Backspace键时,事件源类型为密码或单行、多行文本的, 
//    //并且readonly属性为true或enabled属性为false的,则退格键失效 
//    var flag1 = (ev.keyCode == 8 && (t == "password" || t == "text" || t == "textarea")
//    && (vReadOnly == true || vEnabled != true)) ? true : false;

//    //当敲Backspace键时,事件源类型非密码或单行、多行文本的,则退格键失效 
//    var flag2 = (ev.keyCode == 8 && t != "password" && t != "text" && t != "textarea")
//    ? true : false;

//    //判断 
//    if (flag2) {
//        return false;
//    }
//    if (flag1) {
//        return false;
//    }
//}

////禁止后退键 作用于Firefox、Opera 
//document.onkeypress = banBackSpace;
////禁止后退键 作用于IE、Chrome 
//document.onkeydown = banBackSpace;




//方法三:
////当键盘敲下后退键(Backspace)后 
//1、禁止浏览器自动后退 
//2、但不影响密码、单行文本、多行文本输入框等的回退操作

//处理键盘事件 禁止后退键(Backspace)密码或单行、多行文本框除外 

//<script language="javascript">        
//    javascript:window.history.forward(1); 
//</script>      
View Code

 

最佳方案为方法二,方法一在Chrome和IE下通过在Firefox下不通过。

 

内容全部来源他处:

http://volunteer521.iteye.com/blog/830522/

等等。

转载于:https://www.cnblogs.com/denghuachengle/p/4739436.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值