作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用规则对象添加事件监听器,如下所示
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);
}
});
}
}
然后w/a/s/d按所有警报“右”。我重写了 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);
}
它确实有效,但这是唯一的方法吗?我可以做得更优雅吗?我的意思是,这看起来很奇怪。
最佳答案
创建另一个函数来绑定(bind)事件,试试这个:
for(var i = 0, len = keyMap.length; i < len; ++i) {
if( typeof keyMap[i].action === "function" ) {
binder(keyMap[i]);
}
}
function binder(keyAct) {
document.addEventListener(keyAct.type, function(e) {
if(e.keyCode === keyAct.code) {
keyAct.action(e);
}
});
}
关于javascript - 如何在闭包中使用 'uncapture' 变量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18869600/
我正在尝试使用规则对象添加事件监听器,如下所示 keyMap = [ {name: "Up", type: "keydown", code: 87, action: function(){al
因此,在我们的应用中,我们不会立即收费,而只是创建将charge设置为capture的带区false,这样就不会立即向客户收费。 问题:尽管我们以未捕获的方式创建了收费,但我们是否仍应为客户发出Ref
我是一名优秀的程序员,十分优秀!