摘要:事件冒泡與事件捕獲事件冒泡和事件捕獲分別由微軟和網(wǎng)景公司提出,這兩個(gè)概念都是為了解決頁(yè)面中事件流事件發(fā)生順序的問題。如下假設(shè)三層都有事件監(jiān)聽,這時(shí)我們點(diǎn)擊的小的藍(lán)方框,事件執(zhí)行的順序是怎么樣的呢紅黃藍(lán)事件冒泡微軟提出了名為事件冒泡的事件流。
事件冒泡與事件捕獲
事件冒泡和事件捕獲分別由微軟和網(wǎng)景公司提出,這兩個(gè)概念都是為了解決頁(yè)面中事件流(事件發(fā)生順序)的問題。
如下:假設(shè)三層div都有事件監(jiān)聽,這時(shí)我們點(diǎn)擊的小的藍(lán)方框,事件執(zhí)行的順序是怎么樣的呢
事件冒泡紅黃藍(lán)
微軟提出了名為事件冒泡(event bubbling)的事件流。事件冒泡可以形象地比喻為把一顆石頭投入水中,泡泡會(huì)一直從水底冒出水面。也就是說,事件會(huì)從最內(nèi)層的元素開始發(fā)生,一直向上傳播,直到document對(duì)象。
因此在事件冒泡的概念下在div元素上發(fā)生click事件的順序應(yīng)該是div -> body -> html -> document
網(wǎng)景提出另一種事件流名為事件捕獲(event capturing)。與事件冒泡相反,事件會(huì)從最外層開始發(fā)生,直到最具體的元素。
因此在事件捕獲的概念下在div元素上發(fā)生click事件的順序應(yīng)該是document -> html -> body -> div -> div
addEventListener第三個(gè)參數(shù)默認(rèn)值是false,表示在事件冒泡階段調(diào)用事件處理函數(shù);如果參數(shù)為true,則表示在事件捕獲階段調(diào)用處理函數(shù)。
測(cè)試事件冒泡-點(diǎn)擊藍(lán)色s1 = document.getElementById("s1") s2 = document.getElementById("s2") s3 = document.getElementById("s3") s1.addEventListener("click",function(e){ console.log("紅 冒泡事件");//從底層往上 },false);//第三個(gè)參數(shù)默認(rèn)值是false,表示在事件冒泡階段調(diào)用事件處理函數(shù);如果參數(shù)為true,則表示在事件捕獲階段調(diào)用處理函數(shù)。 s2.addEventListener("click",function(e){ console.log("黃 冒泡事件"); },false); s3.addEventListener("click",function(e){ console.log("藍(lán) 冒泡事件"); },false);測(cè)試事件捕獲-點(diǎn)擊藍(lán)色
s1.addEventListener("click",function(e){ console.log("紅 捕獲事件"); },true); s2.addEventListener("click",function(e){ console.log("黃 捕獲事件"); },true); s3.addEventListener("click",function(e){ console.log("藍(lán) 捕獲事件"); },true);事件捕獲與事件冒泡同時(shí)存在-先捕獲后冒泡
這里記被點(diǎn)擊的DOM節(jié)點(diǎn)為target節(jié)點(diǎn),document 往 target節(jié)點(diǎn),捕獲前進(jìn),遇到注冊(cè)的捕獲事件立即觸發(fā)執(zhí)行
到達(dá)target節(jié)點(diǎn),觸發(fā)事件
對(duì)于target節(jié)點(diǎn)上,是先捕獲還是先冒泡則捕獲事件和冒泡事件的注冊(cè)順序,先注冊(cè)先執(zhí)行
arget節(jié)點(diǎn) 往 document 方向,冒泡前進(jìn),遇到注冊(cè)的冒泡事件立即觸發(fā)
s1.addEventListener("click",function(e){ console.log("紅 冒泡事件"); },false); s2.addEventListener("click",function(e){ console.log("黃 冒泡事件"); },false); s3.addEventListener("click",function(e){ console.log("藍(lán) 冒泡事件"); },false); s1.addEventListener("click",function(e){ console.log("紅 捕獲事件"); },true); s2.addEventListener("click",function(e){ console.log("黃 捕獲事件"); },true); s3.addEventListener("click",function(e){ console.log("藍(lán) 捕獲事件"); },true);應(yīng)用:事件委托(也叫事件代理)
比如我想點(diǎn)擊ul標(biāo)簽里面的li獲取它的值,有點(diǎn)人就會(huì)遍歷去給每個(gè)li加一個(gè)事件監(jiān)聽
其實(shí)我們可以在li的父級(jí)加一個(gè)事件監(jiān)聽,這就相當(dāng)于把事件監(jiān)聽委托給了ul
我們點(diǎn)擊li的時(shí)候是會(huì)打出值的
ul = document.getElementById("ur") ul.addEventListener("click",function(e){ console.log(e.target.innerText); },false);onclick事件分析
onclick不能像addEventListener那樣指定是事件類型,它只能是事件冒泡
s1.onclick=function(){ console.log("紅") } s2.onclick=function(){ console.log("黃") } s3.onclick=function(){ console.log("藍(lán)") return true }阻止事件冒泡和事件默認(rèn)行為
但某一些時(shí)候我們不想觸發(fā)事件冒泡怎么辦或者是不想觸發(fā)默認(rèn)的一些方法
e.stopPropagation()這是W3C的標(biāo)準(zhǔn)方法,stopPropagation是事件對(duì)象(Event)的一個(gè)方法,作用是阻止目標(biāo)元素的冒泡事件,但是會(huì)不阻止默認(rèn)行為。
IE使用的是IE則是使用e.cancelBubble = true
function stopBubble(e) { //如果提供了事件對(duì)象,則這是一個(gè)非IE瀏覽器 if ( e && e.stopPropagation ) //因此它支持W3C的stopPropagation()方法 e.stopPropagation(); else //否則,我們需要使用IE的方式來(lái)取消事件冒泡 window.event.cancelBubble = true; }e.preventDefault()
preventDefault它是事件對(duì)象(Event)的一個(gè)方法,作用是取消一個(gè)目標(biāo)元素的默認(rèn)行為。既然是說默認(rèn)行為,當(dāng)然是元素必須有默認(rèn)行為才能被取消,如果元素本身就沒有默認(rèn)行為,調(diào)用當(dāng)然就無(wú)效了。什么元素有默認(rèn)行為呢?如鏈接,提交按鈕等。當(dāng)Event 對(duì)象的 cancelable為false時(shí),表示沒有默認(rèn)行為,這時(shí)即使有默認(rèn)行為,調(diào)用preventDefault也是不會(huì)起作用的。
return falsejavascript的return false只會(huì)阻止默認(rèn)行為,而是用jQuery的話則既阻止默認(rèn)行為又防止對(duì)象冒泡。
//阻止瀏覽器的默認(rèn)行為 總結(jié) function stopDefault( e ) { //阻止默認(rèn)瀏覽器動(dòng)作(W3C) if ( e && e.preventDefault ) e.preventDefault(); //IE中阻止函數(shù)器默認(rèn)動(dòng)作的方式 else window.event.returnValue = false; return false; }
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/114957.html
摘要:事件冒泡與事件捕獲事件冒泡和事件捕獲分別由微軟和網(wǎng)景公司提出,這兩個(gè)概念都是為了解決頁(yè)面中事件流事件發(fā)生順序的問題。如下假設(shè)三層都有事件監(jiān)聽,這時(shí)我們點(diǎn)擊的小的藍(lán)方框,事件執(zhí)行的順序是怎么樣的呢紅黃藍(lán)事件冒泡微軟提出了名為事件冒泡的事件流。 事件冒泡與事件捕獲 事件冒泡和事件捕獲分別由微軟和網(wǎng)景公司提出,這兩個(gè)概念都是為了解決頁(yè)面中事件流(事件發(fā)生順序)的問題。 如下:假設(shè)三層div都...
摘要:事件冒泡與事件捕獲事件冒泡和事件捕獲分別由微軟和網(wǎng)景公司提出,這兩個(gè)概念都是為了解決頁(yè)面中事件流事件發(fā)生順序的問題。如下假設(shè)三層都有事件監(jiān)聽,這時(shí)我們點(diǎn)擊的小的藍(lán)方框,事件執(zhí)行的順序是怎么樣的呢紅黃藍(lán)事件冒泡微軟提出了名為事件冒泡的事件流。 事件冒泡與事件捕獲 事件冒泡和事件捕獲分別由微軟和網(wǎng)景公司提出,這兩個(gè)概念都是為了解決頁(yè)面中事件流(事件發(fā)生順序)的問題。 如下:假設(shè)三層div都...
摘要:如圖使用事件捕獲模式注冊(cè)事件監(jiān)聽對(duì)最外層,中間層,最內(nèi)層分別用捕獲模式注冊(cè)事件監(jiān)聽,我們上面說了,如果使用捕獲模式,那么第三個(gè)參數(shù)應(yīng)該是,否則則是冒泡模式,如果不聲明,默認(rèn)為冒泡模式。 來(lái)源: 個(gè)人博客 想必好多童鞋都有直接復(fù)制粘貼event.preventDefault() 或者event.stopPropagation() 的經(jīng)歷,但是為什么這樣做不甚了解,今天我們的目的就是要徹...
摘要:事件冒泡一個(gè)簡(jiǎn)單,但是坑了我無(wú)數(shù)回的知識(shí)點(diǎn)與的交互通過事件來(lái)實(shí)現(xiàn)。而瀏覽器的事件流是一個(gè)非常重要的概念。不去討論那些古老的瀏覽器有事件捕獲與事件冒泡的爭(zhēng)議,只需要知道在中規(guī)定的事件流包括了三個(gè)部分,事件捕獲階段處于目標(biāo)階段事件冒泡階段。 打算封裝一個(gè)彈窗組件,做的時(shí)候忘記了考慮事件冒泡的因素,結(jié)果被坑得不要不要的。為了解決自己的問題,去查閱了不少資料,把事件流相關(guān)的知識(shí)都給總結(jié)一下。 ...
閱讀 2350·2019-08-30 15:44
閱讀 1273·2019-08-30 13:01
閱讀 3316·2019-08-30 11:22
閱讀 3103·2019-08-29 15:23
閱讀 1622·2019-08-29 12:22
閱讀 3383·2019-08-26 13:58
閱讀 3450·2019-08-26 12:17
閱讀 3488·2019-08-26 12:16