Loop through array and add event listener “click” to each
我正在尝试迭代一系列元素并为每个元素添加一个事件监听器。
填充数组:
1 | var sliders = [].slice.call(document.getElementsByClassName("sliderControlLi")); |
迭代数组:
1 2 3 4 5 | sliders.forEach(function (i){ addEventListener("click", function(){ console.log("you clicked slider controler" + this.index +"!"); }); }); |
但是使用这段代码,每当我点击任何一个滑块时,我都会获得多个console.log打印输出 - 一次为阵列中的每个滑块。
我找了类似的问题,但我仍然无法解决这个问题。
谢谢你的帮助!
你应该使用
1 | target.addEventListener(type, listener[, options]); |
您还可以从
1 | arr.forEach(function ( element_value,element_index ){ }) |
希望这可以帮助。
1 2 3 4 5 6 7 | var sliders = [].slice.call(document.getElementsByClassName("sliderControlLi")); sliders.forEach(function (element, index){ element.addEventListener("click", function(){ console.log("you clicked slider controler" +index +"!"); }); }); |
1 2 3 4 | slider 1 slider 2 slider 3 slider 4 |
你应该使用
1 2 | EventTarget.addEventListener(...) ^^^^^^^^^^^^ |
所以在你的情况下
1 2 3 | sliders.forEach(function (elem){ elem.addEventListener(...); }); |