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 = ElementById("outDiv");
var middleDiv = ElementById("middleDiv");
var inDiv = ElementById("inDiv");
var info = ElementById("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;
421事件内容
……
最终得出如下结论:
true 的触发顺序总是在 false 之前;
如果多个均为 true,则外层的触发先于内层;
如果多个均为 false,则内层的触发先于外层。