在你的印象裏是否是這樣的target.addEventListener(type, listener[, useCapture])html
target.addEventListener(type, listener [,{capture: Boolean, bubbling: Boolean, once: Boolean}]);chrome
<nav id="menu"><a href="https://juejin.im">首頁</a></nav>
複製代碼
var nav = document.getElementById('menu')
var link = nav.firstElementChild
複製代碼
menu.addEventListener('click', function (e) {
console.log('menu clicked!')
}, { capture: true })
link.addEventListener('click', function (e) {
e.preventDefault();
console.log('link clicked!')
}, { capture: false })
// menu clicked!
// link clicked!
複製代碼
link.addEventListener('click', function (e) {
e.preventDefault();
console.log('link clicked!')
}, { capture: false,once:true })
//輸出一次link clicked!後自動移除listener函數,再次點擊無效。
複製代碼
link.addEventListener('click', function (e) {
e.preventDefault();
console.log('link clicked!')
}, { capture: false,passive:true })
//控制檯輸出:Unable to preventDefault inside
passive event listener invocation.
連接跳轉
複製代碼
使用 passive 改善的滾屏性能,添加passive參數後,touchmove事件不會阻塞頁面的滾動(一樣適用於鼠標的滾輪事件)瀏覽器
addEventListener('touchmove', function listener() {
/* do something */ }, { passive: true });
複製代碼
瀏覽器 | chrome | Firefox | IE |
---|---|---|---|
capture | 49.0 | 49.0 | 未實現 |
passive | 51.0 | 49.0 | 未實現 |
once | 55 | 50 | 未實現 |
注意:那些不支持參數options的瀏覽器,會把第三個參數默認爲useCapture,即設置useCapture爲truebash