Nak*_*tra 6 html javascript event-listener addeventlistener dom-events
我想通过 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>
Run Code Online (Sandbox Code Playgroud)
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);
});
Run Code Online (Sandbox Code Playgroud)
您需要使用querySelectorAllwhich 将返回一个集合。现在使用spread operator(三个点)将其转换为数组并使用forEach.InsideforEach回调向其添加事件侦听器
[...document.querySelectorAll('.breakdown')].forEach(function(item) {
item.addEventListener('click', function() {
console.log(item.innerHTML);
});
});Run Code Online (Sandbox Code Playgroud)
<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>Run Code Online (Sandbox Code Playgroud)
在您的代码段中,您还附加了内联事件处理程序,这可能不是必需的。
如果目标是启用下一个按钮,则function可以从事件处理程序的回调函数中调用以启用它
| 归档时间: |
|
| 查看次数: |
17255 次 |
| 最近记录: |