您的位置
主页 > 网站技术 > 语言编程 > » 正文

javascript阻止浏览器后退事件防止误操作清空表单

来源: 站长圈 点击:

复制代码 代码如下:

//处理键盘事件 禁止后退键(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 : true; 

vEnabled = (vEnabled == null) ? true : vEnabled; 

//当敲Backspace键时,事件源类型为密码或单行、多行文本的, 

//并且readonly属性为true或enabled属性为false的,则退格键失效 

var flag1=(ev.keyCode == 8 && (t=="password" || t=="text" || t=="textarea") 

&& (vReadOnly || 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; 

window.history.forward(1);//屏蔽浏览器自带的后退键 

需要注意的地方是: 

这段代码一定要放到初始化方法中。然后用document.onkeypress=banBackSpace去调用自己写的方法。 

复制代码 代码如下:

vReadOnly = (vReadOnly == null) ? false : true;对于这段代码,原来冒号后面是vReadOnly<span style="font-family: Arial, Helvetica, sans-serif;">这个值,后来发现在我项目中它返回空,不是null于是改成了true。</span> 

按照上面方法即可实现在非text,password,textare时按退格阻止浏览器后退事件,但是不会阻止在文本框有值时的退格事件。这是我的第一篇博客,希望各位多多捧场。 




首页  - 关于站长圈  - 广告服务  - 联系我们  - 关于站长圈  - 网站地图  - 版权声明