【问题标题】:Want to add "addEventListener" on multiple elements with same class想要在具有相同类的多个元素上添加“addEventListener”
【发布时间】:2018-07-28 16:58:05
【问题描述】:

我想通过js中的事件监听器执行“onClick”中的逻辑,但它似乎只运行一次?我有四门课,但我不明白为什么它似乎只适用于第一门?

HTML:

<button id='btn-1' type="button" name="first" class="breakdown main-text" onclick="enableButton('btn-2');disableButton('btn-1');show('btn-1')"> Breakdown Start </button>
<button id='btn-2' type="button" name="second" class="breakdown main-text" onclick="enableButton('btn-3');disableButton('btn-2');show('btn-2')" disabled> Repair Start </button>
<button id='btn-3' type="button" name="third" class="breakdown main-text" onclick="enableButton('btn-4');disableButton('btn-3');show('btn-3')" disabled> Repair End </button>
<button id='btn-4' type="button" name="fourth" class="breakdown main-text" onclick="show('btn-4')" disabled> Breakdown Ended </button>

JS:

let button1 = document.querySelector('#btn-1')
let button2 = document.querySelector('#btn-2');
let button3 = document.querySelector('#btn-3');
let button4 = document.querySelector('#btn-4');


const breakdownButton = document.querySelector('.breakdown');
breakdownButton.addEventListener('click', function() {
console.log(this.innerHTML);
});

【问题讨论】:

标签: javascript html addeventlistener dom-events event-listener


【解决方案1】:

您需要使用querySelectorAll,它将返回一个集合。现在使用spread operator(三个点)将其转换为数组并使用forEach。在forEach回调中添加事件监听器

[...document.querySelectorAll('.breakdown')].forEach(function(item) {
  item.addEventListener('click', function() {
    console.log(item.innerHTML);
  });
   });
<button id='btn-1' type="button" name="first" class="breakdown main-text"> Breakdown Start </button>
<button id='btn-2' type="button" name="second" class="breakdown main-text" disabled> Repair Start </button>
<button id='btn-3' type="button" name="third" class="breakdown main-text" disabled> Repair End </button>
<button id='btn-4' type="button" name="fourth" class="breakdown main-text" disabled> Breakdown Ended </button>

在您的 sn-p 中,您还附加了内联事件处理程序,这可能不是必需的。

如果目标是启用下一个按钮,则可以从事件处理程序的回调函数中调用 function 来启用它

【讨论】:

  • 展开成数组真的有必要吗? forEach 可以在 querySelectorAll 上调用,结果似乎在 Chrome 控制台中。
  • 不幸的是,它不能直接在getElementsByClassName的结果上调用...
  • 任何人都知道为什么这适用于querySelectorAll 而不适用于document.getElementsByClassName
  • @S.. 因为一个返回 NodeList,另一个返回 HTMLCollection。其中只有一个具有forEach 方法。
【解决方案2】:

the documentation 中查看querySelector

querySelector() 返回文档中与指定选择器或选择器组匹配的第一个元素

如果你想匹配多个元素,你需要使用querySelectorAll,因为it doesn't return a single element 循环会覆盖结果。

或者,您可以使用event delegation

【讨论】:

  • 谢谢!在某些情况下,一个比另一个更有价值吗?
  • @NakulMalhotra — 在我链接到的问题中详细解释了事件委托的好处。
【解决方案3】:

需要使用querySelectorAll 而不是querySelector。并像这样遍历列表。

const breakdownButton = document.querySelectorAll('.breakdown');

// It add event listeners for the first button element. 
// you can use forloop or using map function to iterate for the list elements and here i used breakdownButton[0] as an example.

breakdownButton[0].addEventListener('click', function() {
  console.log(this.innerHTML);
});

使用迭代函数,如 forEach 或 map。我用forEach

const breakdownButton = document.querySelectorAll('.breakdown');
breakdownButton.forEach(function(btn) {
  btn.addEventListener('click', function() {
    console.log();
  });
});

【讨论】:

  • [0] 不会遍历列表。它只接受其中的第一个元素。
  • 不这样,我们需要为我给出的示例中的按钮元素添加事件侦听器。
  • (抱歉不是要投反对票..试图取消)
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2018-01-15
  • 1970-01-01
  • 2014-09-27
  • 1970-01-01
相关资源
最近更新 更多