JavaScript中使用stopPropagation函數(shù)停止事件傳播例子
JS中的事件默認是冒泡方式,逐層往上傳播,可以通過stopPropagation()函數(shù)停止事件在DOM層次中的傳播。如以下例子:
HTML代碼:
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>stopPropagation()使用 - 瓊臺博客</title> </head> <body> <button>button</button> </body> </html> [/code] 沒有加stopPropagation() [code] var button = document.getElementsByTagName('button')[0]; button.onclick=function(event){ alert('button click'); }; document.body.onclick=function(event){ alert('body click'); }
DOM逐層往上傳播,所以單擊button按鈕也傳播到了body層,于是body層的click也響應了。結(jié)果彈出兩個警告框,分別是button與body。
加了stopPropagation()
var button = document.getElementsByTagName('button')[0]; button.onclick=function(event){ alert('button click'); // 停止DOM事件層次傳播 event.stopPropagation(); }; document.body.onclick=function(event){ alert('body click'); }
在button的單擊事件處理函數(shù)中使用了stopPropagation()停止事件傳播函數(shù),所以在彈出來自button單擊事件的警告框以后就傳播不到body,也就不會再次彈出body的警告框,結(jié)果只談一次警告框。
好多童鞋在寫JS的時候,往往忽視了DOM事件逐層往上傳播的特性,導致程序出現(xiàn)異常。如果需要了解更深入的知識可以找找有關JS事件冒泡的資料看看。
- MySQL數(shù)據(jù)庫事務隔離級別介紹(Transaction Isolation Level)
- spring事物傳播propagation類別含義詳解
- spring事務Propagation及其實現(xiàn)原理詳解
- python實現(xiàn)BackPropagation算法
- js中的preventDefault與stopPropagation詳解
- 關于event.cancelBubble和event.stopPropagation()的區(qū)別介紹
- Jquery阻止事件冒泡 event.stopPropagation
- 阻止JavaScript事件冒泡傳遞(cancelBubble 、stopPropagation)
- 淺談spring中isolation和propagation的用法
相關文章
JS性能優(yōu)化實現(xiàn)方法及優(yōu)點進行
這篇文章主要介紹了JS性能優(yōu)化實現(xiàn)方法及優(yōu)點進行,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-08-08LayUi使用switch開關,動態(tài)的去控制它是否被啟用的方法
今天小編就為大家分享一篇LayUi使用switch開關,動態(tài)的去控制它是否被啟用的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09通用javascript腳本函數(shù)庫 方便開發(fā)
javascript 在 WEB 編程中能起到很大的作用,將一些常用的功能寫成javascript類庫。2009-10-10原生javascript實現(xiàn)分享到朋友圈功能 支持ios和android
本文主要介紹網(wǎng)上一個牛人寫的js可以實現(xiàn)在UC瀏覽器和QQ瀏覽器中調(diào)用瀏覽器內(nèi)置的分享組件進行分享。2016-05-05用javascript實現(xiàn)jquery的document.ready功能的實現(xiàn)代碼
實現(xiàn)jQuery的document.ready功能js代碼2009-11-11