ホームページ  >  記事  >  ウェブフロントエンド  >  JavaScriptでBackspaceキーを無効にする方法

JavaScriptでBackspaceキーを無効にする方法

PHPz
PHPzオリジナル
2016-05-16 15:27:571407ブラウズ

今日、IE ブラウザで readonly="readonly" 属性 を使用してテキスト ボックスを読み取り専用に設定すると、奇妙な問題が発生することを発見しました。カーソルが読み取り専用のテキスト ボックスに入ると、 Backspace キーを押すと、前のページに戻るのと同じようにブラウザの戻るボタンを押します。ただし、Firefox と Google ではこのような問題は発生しません。以下の処理方法を書きました。テキスト ボックスが読み取り専用の場合、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;
}

この処理を追加すると、「読み込み中にBackspaceキーを押す」という問題は簡単に解決できます。 -IE の入力ボックスのみ「前のページに戻る」問題。

この記事を気に入っていただき、編集者が更新する記事に引き続き注目していただければ幸いです。

【おすすめ関連チュートリアル】

1. JavaScript ビデオチュートリアル
2. JavaScript オンラインマニュアル
3.ブートストラップ チュートリアル

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。