addEventListener 的三個參數
阿新 • • 發佈:2017-06-17
測試 code tel inner 是我 tlist nbsp script func
addEventListener 有三個參數:第一個參數表示事件名稱(不含 on,如 "click");第二個參數表示要接收事件處理的函數;第三個參數為 useCapture,本文就講解它。
<body> <div id="outDiv"> <div id="middleDiv"> <div id="inDiv">請在此點擊鼠標。</div> </div> </div> <div id="info"></div> <script> 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>"; }, 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;
-
……
最終得出如下結論:
-
true 的觸發順序總是在 false 之前;
-
如果多個均為 true,則外層的觸發先於內層;
-
如果多個均為 false,則內層的觸發先於外層。
addEventListener 的三個參數