zoukankan      html  css  js  c++  java
  • addEventListener()第三个参数useCapture (Boolean) 详解

    举例

    <div id="div1">
      <div id="div2">
        <div id="div3">
          <div id="div4">
          </div>
        </div>
      </div>
    </div>

    如果在 d3 上点击鼠标,事件流是这样的:

    捕获阶段 在 div1 处检测是否有 useCapture 为 true 的事件处理程序,若有,则执行该程序,然后再同样地处理 div2。

    目标阶段 在 div3 处,发现 div3 就是鼠标点击的节点,所以这里为目标阶段,若有事件处理程序,则执行该程序,这里不论 useCapture 为 true 还是 false。

    冒泡阶段 在 div2 处检测是否有 useCapture 为 false 的事件处理程序,若有,则执行该程序,然后再同样地处理 div1。

    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,则内层的触发先于外层。

    转载请注明:http://www.tea119.com

  • 相关阅读:
    CNN(卷积神经网络)入门
    基于linux vim环境python代码自动补全
    Linux 基本bash命令
    基于pytorch的CNN、LSTM神经网络模型调参小结
    深度学习中Batch size对训练效果的影响
    argparse.ArgumentParser()用法解析
    大数据学习之Hive数据仓库 20
    centOS中安装MySQL超级方便简单的方法
    大数据学习之zookeeper案例节点动态上下线感知19
    大数据学习之zookeeper客户端的命令行及API操作18
  • 原文地址:https://www.cnblogs.com/wshiqtb/p/3092881.html
Copyright © 2011-2022 走看看