下面我有一个小的JavaScript文件,用于为数组中的每个数组创建元素。除了最后一个函数removeEventListeners()
之外,一切正常。此函数不会返回任何错误,但它不会删除侦听器。
真的很感激任何帮助!感谢。
var array = [["Bob", 17, 1], ["Alan", 16, 1], ["Dave", 19, 1], ["Terry", 5, 1], ["Janet", 23, 0]];
var elements = [];
var AGE = 1;
function createHandler(i) {
return function() {
// Upon clicking the element show an alert with the age of that element (taken from array)
alert(array[i][AGE]);
}
}
for (var i = 0; i < array.length; i++) {
elements[i] = document.createElement("div");
elements[i].addEventListener("click", createHandler(i), false);
}
// This function is where the problem lies - it doesn't remove the handlers
function removeEventListeners() {
for (var i = 0; i < elements.length; i++) {
elements[i].removeEventListener("click", createHandler(i), false);
}
}
答案 0 :(得分:1)
原因是creatHandler
始终返回新函数,而不是您附加的函数。您应该存储处理程序并在想要删除它们时获取它们。
var handlers = [];
function createHandler(i) {
if (!handlers[i]) {
console.log('Created ' + i);
handlers[i] = function () {
alert(array[i][AGE]);
};
}
return handlers[i];
}
您也可以看到它的实际效果:http://jsfiddle.net/balintbako/TQxua/