源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

addEventListener()第三个参数useCapture (Boolean)详细解析

  • 时间:2022-05-14 05:05 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:addEventListener()第三个参数useCapture (Boolean)详细解析
[b]举例[/b] <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; •…… [b]最终得出如下结论:[/b] •true 的触发顺序总是在 false 之前; •如果多个均为 true,则外层的触发先于内层; •如果多个均为 false,则内层的触发先于外层。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部