0

HandsOnTable jquery プラグインを使用しており、特定のキーの組み合わせ ( Alt+ v) ショートカットを処理しようとしています。しかし、何らかの理由で機能していません。ここに私のコードとjsfiddleがあります:

$(document).ready(function () {
var isCtrl = false;
var isShift = false;
var isAlt = false;
// action on key up
$(document).keyup(function (e) {
    if (e.which == 17) {
        isCtrl = false;
    }
    if (e.which == 16) {
        isShift = false;
    }
    if (e.which == 18) {
        isAlt = false;
    }
});
// action on key down
$(document).keydown(function (e) {
    if (e.which == 17) {
        isCtrl = true;
    }
    if (e.which == 16) {
        isShift = true;
    }
    if (e.which == 18) {
        isAlt = true;
    }
    if (e.which == 86 && isAlt) //alt+v
    {
        console.log("alt+v detected");
        e.preventDefault();
        e.stopImmediatePropagation();
        return false;
    }
});
});
4

2 に答える 2

1

私はクロムを使用していますが、すべてのキーダウン イベントが発生しないようです。「キーバインドの変更」に使用できるbeforeKeyDownコールバックがあることがわかりました。それを使用するとうまくいくようです:

$('#example').handsontable({
    data: data,
    minSpareRows: 1,
    colHeaders: true,
    contextMenu: true,
    beforeKeyDown: function (e) {
        if (e.altKey === true && e.which === 86) {
            console.log("alt-v");
            e.stopImmediatePropagation();
            e.preventDefault();
        }
    }
});

http://jsfiddle.net/JdzR3/

于 2013-08-28T19:47:40.083 に答える
0

altkeyjQuery を使用しているため、イベントでプロパティを使用できます。

$(document).on('keydown', function(e){
  var key = e.which || e.keyCode;

  if(e.altKey === true && key === 86){
     console.log("Alt+v");
  } 

});

それとその他の重要なイベントの詳細については、https://developer.mozilla.org/en-US/docs/Web/API/event.altKeyを参照してください。

于 2013-08-28T18:36:37.020 に答える