ホームページ > 記事 > ウェブフロントエンド > JavaScriptでBackspaceキーを無効にする方法
今日、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.ブートストラップ チュートリアル