【JavaScript】兩個截然相反的事件流:事件冒泡與事件捕獲
什麼是事件?
事件是文件和瀏覽器視窗中發生的特定互動的瞬間。
什麼是事件流:
事件流描述的是從頁面中接受事件的順序,但有趣的是,微軟(IE)和網景(Netscape )開發團隊居然提出了兩個相反的事件流概念,IE的事件流是事件冒泡流(event bubbling),而Netscape的事件流是事件捕獲流(event capturing)。
第一種:事件冒泡
IE提出的事件流叫做事件冒泡,即事件開始時由最具體的元素接收,然後逐級向上傳播到較為不具體的節點
p——>body——>html——>document
第二種:事件捕獲
不太具體的節點應該更早接收到事件,最具體的節點應該最後接收到事件。捕獲的目的在於在事件到達預定目標之前捕獲它。
document——>html——>body——>p
#DOM事件流
「DOM2級事件」規定的事件流包括三個階段:事件捕獲階段、處於目標階段、事件冒泡階段
在DOM事件流中,實際的目標在捕獲階段不會接受到事件,這意味著在捕獲階段,事件到達body後就停止了。下一個階段是處於目標階段,於是事件在p上發生,並在事件處理中被視為冒泡階段的一部分。然後,冒泡階段發生,事件又傳回文件。
即使「DOM2級事件」規範明確要求擷取階段不會涉及事件目標,但現在的主流瀏覽器都會在擷取階段觸發事件物件上的事件。結果就是有兩個機會在目標物件上面操作事件。
DOM2級事件處理程序
DOM 2級事件定義了兩方法:用於處理新增事件和刪除事件的操作:
新增事件addEventListener() 刪除事件 removeEventListener()
所有DOM節點中都包含這兩個方法,並且他們都包含3個參數: (1) 要處理的事件方式(例如:click,mouseover,dbclick.....) (2)事件處理的函數,可以為匿名函數,也可以為命名函數(但如果需要刪除事件,必須是命名函數) (3)一個布林值,代表是處於事件冒泡階段處理還是事件擷取階段(true:表示在擷取階段呼叫事件處理程序;false:表示在冒泡階段呼叫事件處理程序)
//这是一个DOM 2级事件 添加事件最简单的方式(此时添加的是一个匿名函数) <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <button>按钮</button> <script> var btn=document.querySelector('button'); btn.addEventListener('click',function(){ console.log('我是按钮') },false) //当第三个参数不写时,也是默认为false(冒泡时添加事件) </script> </body> </html>
//添加的函数是命名函数,removeEventListener需要用这种方式 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <button>按钮</button> <script> var btn=document.querySelector('button'); btn.addEventListener('click',foo,false); function foo(){ console.log('我是按钮') } //其实操作就是把写在里面的函数拿到了外面,而在原来的位置用函数名来代替 </script> </body> </html>
DOM2級處理程序也支援新增兩個事件處理事件,那麼兩個事件都會執行
大多數情況下,我們都是將事件處理程序添加到事件流的冒泡階段,這樣可以最大限度的兼容各種瀏覽器。
最好只在需要在事件到達目標之前截獲它的時候,將事件處理程序新增到擷取階段。
如果不是特別需要,不建議在事件擷取階段註冊事件處理程序。
阻止事件冒泡
主要是用來阻止事件傳播。阻止它被分派到其他的DOM節點上,在事件傳播的任何階段都能使用。使用方法如下(相容IE):
function stopBubble(event){ if(window.event){ //兼容IE window.event.cancelBubble=true; }else{ event.stopPropagation(); } }
阻止預設事件
function stopDefaultEvent(event){ if(window.event){ //兼容IE window.event.returnValue=false; }else{ event.preventDefault() } return false; }
相關文章:
相關影片:
以上是【JavaScript】兩個截然相反的事件流:事件冒泡與事件捕獲的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

Python和JavaScript開發者的薪資沒有絕對的高低,具體取決於技能和行業需求。 1.Python在數據科學和機器學習領域可能薪資更高。 2.JavaScript在前端和全棧開發中需求大,薪資也可觀。 3.影響因素包括經驗、地理位置、公司規模和特定技能。

如何在JavaScript中將具有相同ID的數組元素合併到一個對像中?在處理數據時,我們常常會遇到需要將具有相同ID�...

學習JavaScript不難,但有挑戰。 1)理解基礎概念如變量、數據類型、函數等。 2)掌握異步編程,通過事件循環實現。 3)使用DOM操作和Promise處理異步請求。 4)避免常見錯誤,使用調試技巧。 5)優化性能,遵循最佳實踐。

實現視差滾動和元素動畫效果的探討本文將探討如何實現類似資生堂官網(https://www.shiseido.co.jp/sb/wonderland/)中�...

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

深入探討console.log輸出差異的根源本文將分析一段代碼中console.log函數輸出結果的差異,並解釋其背後的原因。 �...
