このように、ルール オブジェクトを使用してイベント リスナーを追加しようとしています。
keyMap = [
{name: "Up", type: "keydown", code: 87, action: function(){alert("up")}},
{name: "Down", type: "keydown", code: 83, action: function(){alert("down")}},
{name: "Left", type: "keydown", code: 65, action: function(){alert("left")}},
{name: "Right", type: "keydown", code: 68, action: function(){alert("right")}}
]
for(var keyAct of keyMap){
if( typeof keyAct.action === "function" ){
document.addEventListener(keyAct.type, function(e){
if(e.keyCode === keyAct.code){
keyAct.action(e);
}
});
}
}
次に、警告されたすべての「右」を押します。for
この部分を次のように書き直しました。
for(var keyAct of keyMap){
(function(keyAct){
if( typeof keyAct.action === "function" ){
document.addEventListener(keyAct.type, function(e){
if(e.keyCode === keyAct.code){
keyAct.action(e);
}
});
}
})(keyAct);
}
それは機能しますが、これがそうする唯一の方法ですか?もっとエレガントにできますか?つまり、これは奇妙に見えます。