-1

押せるキーを制限したい。

$('.txtComments').keydown(function (event) {
  var keys = new Array();
  keys[0] = "8";
  keys[1] = "46";
  keys[2] = "37"
  keys[3] = "39"

  if(!(....)) //Check whether the keyCode is either of 8, 46, 37, or 39. 
  {
     event.preventDefault();  
  }
});

助けてくれてありがとう

4

5 に答える 5

3

ここで最も簡単な (そして最速の) 方法は、オブジェクトを map として使用することです。

   var keys = {};
   keys[8] = true;
   ...

   if (!keys[event.which]) {
     ...

互換性を高めるために、キーコードの代わりにevent.whichを使用することをお勧めします。

于 2013-03-05T19:07:00.863 に答える
2

これを実装するには非常に多くの方法があります。

ハードコーディングするだけです:

var keyCode = event.which;

if (keyCode != 8 && keyCode != 46 ...)

または配列を確認します。

var keys = [8, 46, ...];
if (keys.indexOf(keyCode) < 0)

または同等のjQuery:

if ($.inArray(keyCode, keys) < 0)

またはオブジェクトをチェックします。

var keys = { 8: 1, 46: 1, ... }
if (! (keyCode in keys) )  // or if (!keys[keyCode])

またはスイッチ:

switch (keyCode) {
    case 8: case 46: ...
        // do nothing
        break;
    default:
        event.preventDefault();
}
于 2013-03-05T19:08:24.950 に答える
1

jQuery.inArray()jQuery には、配列に値が含まれているかどうかを確認するためのユーティリティ メソッドが用意されています。

于 2013-03-05T19:07:48.080 に答える
0

if(!keys.in_array(event.keyCode));

そしてあなたkeydownをに変えてくださいkeypress

<script type="text/javascript">
// Benoit Asselin - http://www.ab-d.fr
Array.prototype.in_array = function(p_val) {
    for(var i = 0, l = this.length; i < l; i++) {
        if(this[i] == p_val) {
            return true;
        }
    }
    return false;
}
</script>
于 2013-03-05T19:07:43.603 に答える
0

あなたが使用することができます: -

   var keys = [];
    keys[8] = keys[4] = keys[37] = keys[39] = true;

if(keys[keyval]){

}
于 2013-03-05T19:17:11.617 に答える