循环中有多个不同的事件侦听器
Multiple different event listeners in for loop
下面的代码总是返回undefined。为什么会这样?我希望事件侦听器使用索引的字符串进行响应。
感谢
var array = ["Hey", "Hi", "Hello"];
for (var i = 0; i < array.length; i++) {
var box = document.createElement("div");
box.className = "box";
box.addEventListener("click", function() {
alert(array[i]);
}, false);
}
这个问题经常被问到。JavaScript没有块作用域。只有在调用函数时才会创建变量范围。因此,要将i
的范围扩大到当前循环迭代,需要在创建处理程序的函数调用中引用它。
// Create a function that returns a function
function createHandler(i) {
// The value of `i` is local to this variable scope
// Return your handler function, which accesses the scoped `i` variable
return function() {
alert(array[i]);
}
}
var array = ["Hey", "Hi", "Hello"];
for (var i = 0; i < array.length; i++) {
var box = document.createElement("div");
box.className = "box";
// Invoke the `createHandler`, and pass it the value that needs to be scoped.
// The returned function will use its reference to the scoped `i` value.
box.addEventListener("click", createHandler(i), false);
}
我强烈建议您使用命名函数,而不是流行的内联函数调用。它可能更高效,函数名称提供了有关函数用途的文档。
您需要将点击处理程序包装在一个闭包中,以创建i
:的本地副本
box.addEventListener("click", (function(i) {
return function() {
alert(array[i]);
}
})(i), false);
Fiddle
按照现在的代码,i
的值为3,而array[3]
当然是未定义的。上面创建了值为0、1、2的i
的3个副本。
可能最简单的解决方案是:
box.addEventListener("click", alert.bind(window, array[i]), false);
但这在IE<9.
相关文章:
- 如何在for循环中添加事件侦听器
- 未命中服务器发送的事件侦听器
- 如何覆盖原型中的事件侦听器
- 无法将事件侦听器附加到画布
- 如何在d3.js中自定义事件侦听器
- 在es6中,将带有回调的事件侦听器设置为可迭代的
- 事件侦听器未在chrome扩展中的options.js中启动
- IE8更改文本区域上的事件侦听器不工作
- 将事件侦听器添加到文档,而不是签入元素存在,然后添加事件侦听器
- javascript删除事件侦听器
- 我应该/如何清除mousemove JQuery事件侦听器
- 在JQuery中使用谷歌地图Api事件/侦听器
- 如何使用我的Jquery代码创建委托事件侦听器
- 'mousemove'画布中的事件侦听器-指针仅在最后一个矩形中更改
- 为什么此事件侦听器不工作
- 是否可以在数字输入框中的小按钮中添加事件侦听器
- 在Google Chrome扩展中添加事件侦听器
- SVG元素在转换后会丢失事件侦听器
- jQuery事件侦听器多次启动
- 如何在不删除类似侦听器的情况下从父对象中删除jQuery事件侦听器