控件为只读时,禁用退格键

当控件为只读时,你按下Backspace键盘键的时候,在IE就会跳到上一级页面。控件在只读时候禁用Backspace.

方法一:单个时间禁用

//禁止Backspace键

function banBackspace(){

   var c = event.keyCode;

  if(ev.keyCode == 8){
     event.returnValue=false;

  }

}


<input  id="supplierName" class="easyui-validatebox" required="required" value="${purchaseOrder.supplierName}" readonly="readonly" οnkeydοwn="banBackspace()" ></input>


其实这个方法在IE有效,火狐没有效果,但是火狐不存在退格返回上一级页面问题。所以可以不解决。其实解决也可以把方法改为

//禁止Backspace键

function banBackspace(ev){

  if(ev.keyCode == 8){
     event.returnValue=false;

  }

}

<input  id="supplierName" class="easyui-validatebox" required="required" value="${purchaseOrder.supplierName}" readonly="readonly" οnkeydοwn="banBackspace( event)" ></input>


方法二:上个方法有弊端,因为我们需要整个完整都禁用该时间,那么我们要设置全局才行。我试过获取所有控件,然后条件遍历,设置,但这个是不行的,js报错,因为获取的控件对象太多了,无法遍历。下面有个很好的方法:

//禁止Backspace键
function forbidBackSpace(e) {
       var ev = e || window.event; //获取event对象
       var obj = ev.target || ev.srcElement; //获取事件源
       var t = obj.type || obj.getAttribute('type'); //获取事件源类型
       //获取作为判断条件的事件类型
       var vReadOnly = obj.readOnly;
       var vDisabled = obj.disabled;
       //处理undefined值情况
       vReadOnly = (vReadOnly == undefined) ? false : vReadOnly;
       vDisabled = (vDisabled == undefined) ? true : vDisabled;
       //当敲Backspace键时,事件源类型为密码或单行、多行文本的,
       //并且readOnly属性为true或disabled属性为true的,则退格键失效
       var flag1 = ev.keyCode == 8 && (t == "password" || t == "text" || t == "textarea") && (vReadOnly == true || vDisabled == true);
       //当敲Backspace键时,事件源类型非密码或单行、多行文本的,则退格键失效
       var flag2 = ev.keyCode == 8 && t != "password" && t != "text" && t != "textarea";
       //判断
       if (flag2 || flag1) return false;
    }

$(function() {

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

});



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值