详解addEventListener的三个参数之useCapture
2015-03-16 10:34
579 查看
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,则内层的触发先于外层。
以上就是本文的全部内容了,希望大家能够喜欢。
您可能感兴趣的文章:
- Javascript 的addEventListener()及attachEvent()区别分析
- addEventListener 的用法示例介绍
- window.addEventListener来解决让一个js事件执行多个函数
- document.addEventListener使用介绍
- JS在IE和FF下attachEvent,addEventListener学习笔记
- 事件绑定之小测试 onclick && addEventListener
- javascript attachEvent和addEventListener使用方法
- addEventListener()第三个参数useCapture (Boolean)详细解析
- 讲两件事:1.this指针的用法小探. 2.ie的attachEvent和firefox的addEventListener在事件处理上的区别
- addEventListener()与removeEventListener()解析
相关文章推荐
- addEventListener的三个参数之useCapture
- socket心跳机制so_keepalive设计三个参数详解
- 详解TCP/IP协议的含义及三个参数
- Gentoo 2005.1 完整的USE参数清单中文详解
- java参数后面 跟 三个点 含义 详解
- socket心跳机制so_keepalive的三个参数详解
- socket心跳机制so_keepalive的三个参数详解
- 详解TCP/IP协议的含义及三个参数
- TCP/IP Socket心跳机制so_keepalive的三个参数详解
- SQL SERVER中的ROUND()函数有三个参数详解
- java参数后面 跟 三个点 含义 详解
- TCP/IP Socket心跳机制so_keepalive的三个参数详解
- Gentoo 完整的USE参数清单中文详解(转)
- java 参数类型后跟三个点详解:test(String... s)
- Linux下的TCP/IP Socket心跳机制so_keepalive的三个参数详解
- 在 DW 中插入 Flash 的参数详解
- 小日本参数设定详解
- window.open()--窗口参数详解!
- GCC参数详解
- 详解 Tomcat: The value for the useBean class attribute is invalid 问题