考虑下面的代码:遍历JavaScript对象绑定密钥
controls = {
'w': 'up',
's': 'down',
'a': 'left',
'd': 'right'
};
keysPressed = [];
for (control in controls) {
direction = controls[control];
$(document).bind('keydown', control, function() {
keysPressed.push(direction);
});
}
只有right
方向被约束,并且它被绑定到所有四个键。这显然不是有意的,但是我错过了关于JavaScript的所有属性被禁止适当绑定的内容?
编辑:
为了澄清,我使用jQuery.hotkeys处理的键名。这是一个片段;你可以假设所有的变量已经被声明。此外,代码在安全function
包装。
SOLUTION:
我这个修改解决了它:
controls = {
'w': 'up',
's': 'down',
'a': 'left',
'd': 'right'
};
keysPressed = [];
addToKeyPressArray = function(value) {
return function() {
keysPressed.push(value);
};
};
removeFromKeyPressArray = function(value) {
return function() {
keysPressed = keysPressed.filter(value);
};
};
for (control in controls) {
direction = controls[control];
$(document).bind('keydown', control, addToKeyPressArray(direction));
$(document).bind('keyup', control, removeFromKeyPressArray(direction));
}
这是一个奇怪的JavaScript怪癖。
所有这些变量都是在上面的某个地方声明的,对吧? –
是的。这是一个片段。 – mybuddymichael
“bind()”的第二个参数应该是一个对象(表示事件数据),而不是一个字符串。 –