addEventListener 的三个参数

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了addEventListener 的三个参数相关的知识,希望对你有一定的参考价值。

addEventListener 有三个参数:第一个参数表示事件名称(不含 on,如 "click");第二个参数表示要接收事件处理的函数;第三个参数为 useCapture,本文就讲解它。

<body>
<div id="outDiv">
  <div id="middleDiv">
    <div id="inDiv">请在此点击鼠标。</div>
  </div>
</div>

<div id="info"></div>
 
<script>
        var outDiv = document.getElementById("outDiv");
    var middleDiv = document.getElementById("middleDiv");
    var inDiv = document.getElementById("inDiv");
    var info = document.getElementById("info");
     
    outDiv.addEventListener("click", function () { info.innerhtml += "outDiv" + "<br>"; }, true);
    middleDiv.addEventListener("click", function () { info.innerHTML += "middleDiv" + "<br>"; }, false);
    inDiv.addEventListener("click", function () { info.innerHTML += "inDiv" + "<br>"; }, true);
</script>
</body>    

 

上述是我们测试的代码,根据 info 的显示来确定触发的顺序,有三个 addEventListener,而 useCapture 可选值为 true 和 false,所以 2*2*2,可以得出 8 段不同的程序。

  • 全为 false 时,触发顺序为:inDiv、middleDiv、outDiv;

  • 全为 true 时,触发顺序为:outDiv、middleDiv、inDiv;

  • outDiv 为 true,其他为 false 时,触发顺序为:outDiv、inDiv、middleDiv;

  • middleDiv 为 true,其他为 false 时,触发顺序为:middleDiv、inDiv、outDiv;

  • ……

最终得出如下结论:

  • true 的触发顺序总是在 false 之前;

  • 如果多个均为 true,则外层的触发先于内层;

  • 如果多个均为 false,则内层的触发先于外层。

以上是关于addEventListener 的三个参数的主要内容,如果未能解决你的问题,请参考以下文章

js中addEventListener第三个参数涉及到的事件捕获与冒泡

addEventListener()第三个参数设置为true和false的区别?

addEventListener和attachEvent主要有几个区别

addEventListener和attachEvent以及element.onclick的区别

Js事件传播流程

onclick和addEventListener的区别