栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > JavaScript

Ext JS框架程序中阻止键盘触发回退或者刷新页面的代码分享

JavaScript 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Ext JS框架程序中阻止键盘触发回退或者刷新页面的代码分享

在 Extjs 开发中,我们需要屏蔽一些键盘按键,来避免用户在使用键盘操作的过程中不小心按到这些快捷键造成输入信息丢失等问题.

Ext.onReady(function(){    
      Ext.WindowMgr.zseed = 10000;  
      Ext.QuickTips.init();   
  
      Ext.getDoc().on("contextmenu", function(e){    
 e.stopEvent();    
      });   
 
      if(document.addEventListener){  
 document.addEventListener("keydown",maskBackspace, true);  
      }else{  
 document.attachEvent("onkeydown",maskBackspace);  
      }  
 
      function maskBackspace(event){  
 var event = event || window.event; //标准化事件对象  
 var obj = event.target || event.srcElement;  
 var keyCode = event.keyCode ? event.keyCode : event.which ?  
     event.which : event.charCode;  
 if(keyCode == 8){  
   if(obj!=null && obj.tagName!=null && (obj.tagName.toLowerCase() == "input"   
|| obj.tagName.toLowerCase() == "textarea")){  
     event.returnValue = true ;  
     if(Ext.getCmp(obj.id)){  
if(Ext.getCmp(obj.id).readOnly) {  
  if(window.event)  
    event.returnValue = false ; //or event.keyCode=0  
  else  
    event.preventDefault();  //for ff  
}  
     }  
   }else{  
     if(window.event)  
event.returnValue = false ;  // or event.keyCode=0  
     else  
event.preventDefault();  //for ff  
   }  
 }  
      }  
 
      var map = new Ext.KeyMap(document, [  
      {  
 key: [116], // F5  
 fn: function(){ },  
 stopEvent: true,  
 scope: this  
      },{  
 key: [37,39,115], //方向键左,右,F4  
 alt: true,  
 fn: function(){ },  
 stopEvent: true,  
 scope: this  
      }, {  
 key: [82], // ctrl + R  
 ctrl: true,  
 fn: function(){ },  
 stopEvent: true,  
 scope: this  
      }]);  
      map.enable();  
});  

禁止在IE8中使用 F5 刷新还需加上代码 :

  

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/96345.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号