循环遍历数组并添加事件侦听器"click"到每个

Run*_*olk 3 javascript arrays addeventlistener onclicklistener

我正在尝试迭代一系列元素并为每个元素添加一个事件监听器.

填充数组:

var sliders = [].slice.call(document.getElementsByClassName("sliderControlLi"));
Run Code Online (Sandbox Code Playgroud)

迭代数组:

sliders.forEach(function (i){
  addEventListener("click", function(){
    console.log("you clicked slider controler " + this.index + "!");
  });
});
Run Code Online (Sandbox Code Playgroud)

但是使用这段代码,每当我点击任何一个滑块时,我都会获得多个console.log打印输出 - 一次为阵列中的每个滑块.

我找了类似的问题,但我仍然无法解决这个问题.

谢谢你的帮助!

Zak*_*rki 9

你应该addEventListener()用作:

target.addEventListener(type, listener[, options]);
Run Code Online (Sandbox Code Playgroud)

您还可以从forEach以下位置获取索引:

arr.forEach(function ( element_value,element_index ){ })
Run Code Online (Sandbox Code Playgroud)

希望这可以帮助.

var sliders = [].slice.call(document.getElementsByClassName("sliderControlLi"));

sliders.forEach(function (element, index){
  element.addEventListener("click", function(){
    console.log("you clicked slider controler " +index + "!");
  });
});
Run Code Online (Sandbox Code Playgroud)
<div class="sliderControlLi">slider 1</div>
<div class="sliderControlLi">slider 2</div>
<div class="sliderControlLi">slider 3</div>
<div class="sliderControlLi">slider 4</div>
Run Code Online (Sandbox Code Playgroud)