gpt4 book ai didi

javascript - 事件处理程序优先级并在某些情况下忽略其他处理程序

转载 作者:行者123 更新时间:2023-11-30 15:39:01 24 4
gpt4 key购买 nike

我有一个带有 2 个 mousedown 事件处理程序的 div,例如

someDiv.addEventListener('mousedown', h1)
someDiv.addEventListener('mousedown', h2)

据我了解,h1 将首先被调用,然后 h2 将被调用,有没有办法在给定条件的情况下停止从 h1 内调用 h2?

最佳答案

在现代浏览器上有,是的:Event#stopImmediatePropagation :

function h1(e) {
if (someCondition) {
e.stopImmediatePropagation();
}
}

实例:

var someDiv = document.getElementById("someDiv");
someDiv.addEventListener('mousedown', h1);
someDiv.addEventListener('mousedown', h2);

var counter = 0;
function h1(e) {
if (counter > 0) {
console.log("h1: Got mousedown, stopping immediate propagation");
e.stopImmediatePropagation();
} else {
console.log("h1: Got mousedown, allowing propagation");
this.innerHTML = "Click me again";
++counter;
}
}

function h2() {
console.log("h2 called");
}
<div id="someDiv">Click me</div>

关于javascript - 事件处理程序优先级并在某些情况下忽略其他处理程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41096432/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com