我正在尝试使用 for 循环向多个对象添加事件侦听器,但最终所有侦听器都针对同一对象 --> 最后一个。
如果我通过为每个实例定义 boxa 和 boxb 手动添加侦听器,它会起作用。我猜是 addEvent for 循环没有按我希望的方式工作。也许我完全使用了错误的方法。
在容器 4 上使用 class="container" Trigger 中的 4 的示例按预期的方式工作。触发容器 1、2、3 触发容器 4 上的事件,但前提是触发器已被激活。
// Function to run on click:
function makeItHappen(elem, elem2) {
  var el = document.getElementById(elem);
  el.style.backgroundColor = "red";
  var el2 = document.getElementById(elem2);
  el2.style.backgroundColor = "blue";
}
// Autoloading function to add the listeners:
var elem = document.getElementsByClassName("triggerClass");
for (var i = 0; i < elem.length; i += 2) {
  var k = i + 1;
  var boxa = elem[i].parentNode.id;
  var boxb = elem[k].parentNode.id;
  elem[i].addEventListener("click", function() {
    makeItHappen(boxa, boxb);
  }, false);
  elem[k].addEventListener("click", function() {
    makeItHappen(boxb, boxa);
  }, false);
}
<div class="container">
  <div class="one" id="box1">
    <p class="triggerClass">some text</p>
  </div>
  <div class="two" id="box2">
    <p class="triggerClass">some text</p>
  </div>
</div>
<div class="container">
  <div class="one" id="box3">
    <p class="triggerClass">some text</p>
  </div>
  <div class="two" id="box4">
    <p class="triggerClass">some text</p>
  </div>
</div>