JavaScript如何禁止Backspace键
2015-12-02 00:00
656 查看
今天在IE浏览器下发现,当把使用readonly="readonly"属性将文本框设置成只读<input type="text" readonly="readonly"/>时有一个奇怪的问题:如果光标进入只读文本框,然后按下Backspace键,就会跳转到上一个页面,效果就像点击了浏览器的后退按钮返回前一个页面一样,而在火狐和google下没有这样的问题出现,为了解决这个问题,写了一个如下的处理方法,如果文本框是只读的,那么就禁用Backspace键。
代码如下:
加上这样的处理之后,就可以轻松解决“只读输入框在IE下按下Backspace键回退到前一个页面”的问题了。
希望大家喜欢这篇文章,继续关注小编更新整理的文章。
javascript实现网页屏蔽Backspace事件,输入框不屏蔽
代码如下:
//处理键盘事件 禁止后退键(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'); //处理null值情况 vReadOnly = (vReadOnly == "") ? false : vReadOnly; //当敲Backspace键时,事件源类型为密码或单行、多行文本的, //并且readonly属性为true或enabled属性为false的,则退格键失效 var flag1=(ev.keyCode == 8 && (t=="password" || t=="text" || t=="textarea") && vReadOnly=="readonly")?true:false; //当敲Backspace键时,事件源类型非密码或单行、多行文本的,则退格键失效 var flag2=(ev.keyCode == 8 && t != "password" && t != "text" && t != "textarea") ?true:false; //判断 if(flag2){ return false; } if(flag1){ return false; } } window.onload=function(){ //禁止后退键 作用于Firefox、Opera document.onkeypress=banBackSpace; //禁止后退键 作用于IE、Chrome document.onkeydown=banBackSpace; }
加上这样的处理之后,就可以轻松解决“只读输入框在IE下按下Backspace键回退到前一个页面”的问题了。
希望大家喜欢这篇文章,继续关注小编更新整理的文章。
您可能感兴趣的文章:
javascript禁制后退键(Backspace)实例代码javascript实现网页屏蔽Backspace事件,输入框不屏蔽
相关文章推荐
- 如何动态加载外部Javascript文件
- JS折半插入排序算法实例
- 简单实现JS对dom操作封装
- JSON保存文件时候不丢转义符号
- Web中的中文乱码问题
- JavaScript简介
- JavaScript变量
- 使用json web token(jwt)
- 关于如何在javascript中实现DI
- js的异步调用
- jsp调java代码输出图片
- javascript:Array.slice.call 到Array.prototype.slice.call
- JSP 自定义标签 (custom tags) 入门介绍
- js传参数的问题。
- 使用T4模板合并js文件
- 浅谈JavaScript浮点数及其运算
- JavaScript中的事件函数传参
- Protobuf与Json互转
- 搭建 tty.js:一款基于浏览器的终端模拟器
- javascript实现无兼容性问题返回顶部