控件为只读时,禁用退格键
来源:互联网 发布:linux配置代理服务器 编辑:程序博客网 时间:2024/05/17 03:50
当控件为只读时,你按下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" onkeydown="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" onkeydown="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;
});
- 控件为只读时,禁用退格键
- js 禁用只读文本框获得焦点时的退格键
- 禁用只读文本框获得焦点时的退格键
- 禁用只读文本框获得焦点时的退格键
- js 禁用只读文本框获得焦点时的退格键
- 设置FileUpload控件为只读
- Jquery显示和隐藏元素或设为只读(含Ligerui的控件禁用,实例说明)
- 禁用页面控件(即改为只读)的方式
- win32 设置Edit控件为只读
- js禁用只读文本框获得焦点时的回格键
- MVC中HTML控件设为只读readonly
- 只读或者禁用usb驱动
- 当Ewebeditor数据库为只读时..
- SqlServer附加数据库时为只读
- 递归设置当前用户控件下的所有服务器控件为只读状态
- 页面只读输入控件
- ExtJs日期控件只读
- SWT 中控件只读
- Codeforces Round #266 (Div. 2) C Number of Ways
- How to Uninstall Apache Server
- Spring 之 定制bean的性质
- android 学习--异步任务类AsyncTask
- 字符串的全排列和组合算法
- 控件为只读时,禁用退格键
- GARCH(三)
- 黑马程序员——Java集合框架—Map
- android:sign
- hdu4994Revenge of Nim(博弈)
- Linux之数据流重导向
- 数字格式化代码
- 网狐机器人玩一局就退出的原因
- Cocos2d-x学习笔记(四)-------->场景切换