【问题标题】:event handler priority and ignoring other handlers on some condition事件处理程序优先级并在某些情况下忽略其他处理程序
【发布时间】:2016-12-12 08:00:55
【问题描述】:

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

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

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

【问题讨论】:

    标签: javascript dom-events


    【解决方案1】:

    在现代浏览器上有,是的: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>

    【讨论】:

      猜你喜欢
      • 2011-03-22
      • 1970-01-01
      • 1970-01-01
      • 2023-03-24
      • 2011-09-28
      • 2019-02-15
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多