4

私はmeteorを使用してデータベース内のドキュメントを更新しています。ただし、キーダウンは機能していないようです。これがコードです。

Template.leaderboard.events({
    'keydown button.inc': function(evt) {
        if (evt.which === 39) {
            Players.update(Session.get("character"), {$inc: {score: 20}});
        }

        Players.update(Session.get("character"), {$inc: {score: 20}});
        //Players.update(Session.get("character"), {$set: {name: 'images/characters/ninja.png'}});
    },
    'keydown': function(evt) {
        if (evt.which === 37) {
            Players.update(Session.get("character"), {$inc: {score: -20}});
            //Players.update(Session.get("character"), {$set: {name: 'images/characters/ninjaleft.png'}});
        }
        Players.update(Session.get("character"), {$inc: {score: -20}});
    }
});

キーダウンが機能しないのはなぜですか?

4

1 に答える 1

9

次のように、テキストエリアと入力にキーボード イベントをアタッチすることに成功しました。

Template.inputArea.events({
  'keydown textarea' : function(e){
     console.log(e.which);
  }
});

私は、キーボード イベントを他の DOM 要素にアタッチすることにあまり慣れていません。イベントについてwindowは、jQueryを使用してキーダウン入力を添付する必要がありました。

Template.foo.rendered = function(){
  $(window).on('keydown', function(e){
    console.log(e.which);
  });
};

// and on newer versions 

Template.foo.onRendered( function() {
    $(window).on('keydown', function(e){
        console.log(e.which);
    });
});

たぶん、あなたはそのようなものを試すことができます...

于 2013-03-17T23:29:06.247 に答える