zoukankan      html  css  js  c++  java
  • 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,则内层的触发先于外层。

  • 相关阅读:
    C++primer plus第六版课后编程题答案7.2
    sprintf函数
    sscanf函数
    [转]Visual Studio 2012 编译错误【error C4996: 'scanf': This function or variable may be unsafe. 】的解决方案
    C/C++动态二维数组的内存分配和释放
    malloc动态分配多维数组
    区间重合判断[poj2808 校门外的树]
    C++中的sort函数
    C语言qsort
    [转]Linux统计代码行数
  • 原文地址:https://www.cnblogs.com/tiger95/p/7039898.html
Copyright © 2011-2022 走看看