• addEventListener-第三个参数 useCapture


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

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

    <div id="info"></div>

     

    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>"; }, false);
    middleDiv.addEventListener("click", function () { info.innerHTML += "middleDiv" + "<br>"; }, false);
    inDiv.addEventListener("click", function () { info.innerHTML += "inDiv" + "<br>"; }, false);

    上述是我们测试的代码,根据 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,则内层的触发先于外层。

    下面提供全部代码,您可以更改其中的 true、false 值,来进行测试。注意,不适用于 IE。


  • 相关阅读:
    linux 配置文件.conf 非打印字符出错的研究(一)
    Python:Relative import 相对路径 ValueError: Attempted relative import in non-package
    GitHub desktop 管理 gitee 私有库
    python enumerate ,range下标迭代
    everything http服务器局域网不能访问 // Windows evething http server connect timeout in lan
    python install jnius, sikuli ;Exception: Unable to determine JDK_HOME
    sublime3 自定义 修改 颜色主题 配色方案
    python K线 蜡烛图
    IOError: [Errno 22] invalid mode ('rb') or filename: ’u202a’ / 'xe2x80xaa’
    [资源]汇集最有用的PHP资源
  • 原文地址:https://www.cnblogs.com/zsw-1993/p/4879805.html
Copyright © 2020-2023  润新知