一、冒泡事件簡(jiǎn)介
當(dāng)我們點(diǎn)擊一個(gè)控件的時(shí)候,如果包括這個(gè)控件的父控件也有click事件,則會(huì)繼續(xù)執(zhí)行。
比如:div下的a都有click事件,點(diǎn)擊a的時(shí)候,會(huì)alert出現(xiàn)2次。這個(gè)現(xiàn)象叫做冒泡事件。
這個(gè)事件從原始元素開始一直冒泡到DOM樹的最上層。
目標(biāo)元素: 任何一個(gè)事件的目標(biāo)元素都是最開始的那個(gè)元素,在我們的這個(gè)例子中也就是按鈕,
并且它在我們的元素對(duì)象中以屬性的形式出現(xiàn)。使用事件代理的話我們可以把事 件處理器添加到一個(gè)元素上,
等待一個(gè)事件從它的子級(jí)元素里冒泡上來,并且可以很方便地得知這個(gè)事件是從哪個(gè)元素開始。
注意:
blur、focus、load和unload不能像其它事件一樣冒泡。事實(shí)上blur和focus可以用事件捕獲而非事件冒泡的方法獲得(在IE之外的其它瀏覽器中)。
二、阻止jQuery事件冒泡
jQuery對(duì)DOM的事件觸發(fā)具有冒泡特性。有時(shí)利用這一特性可以減少重復(fù)代碼,但有時(shí)候我們又不希望事件冒泡。這個(gè)時(shí)候就要阻止 jQuery.Event冒泡。
在jQuery.Event的文檔中的開頭得知,jQuery.Event對(duì)象是符合W3C標(biāo)準(zhǔn)的一個(gè)事件對(duì)象,同時(shí)jQuery.Event免去了檢查兼容IE的步驟。
jQuery.Event提供了一個(gè)非常簡(jiǎn)單的方法來阻止事件冒泡:event.stopPropagation();
但是這個(gè)方法對(duì)使用live綁定的事件沒有作用,需要一個(gè)更簡(jiǎn)單的方法阻止事件冒泡:return false;
return false; });
兼容多個(gè)瀏覽器的終止冒泡函數(shù):
三、使用event.tatget屬性 明確事件對(duì)象
事件處理程序中的變量event保存著事件對(duì)象。而event.tatget屬性保存著發(fā)生事件的目標(biāo)元素。這個(gè)屬性是DOM API中規(guī)定的,但是沒有被所有瀏覽器實(shí)現(xiàn)。jQuery對(duì)這個(gè)事件對(duì)象進(jìn)行了必要的擴(kuò)展,從而在任何瀏覽器中都能夠使用這個(gè)屬性。通過.target,可以確定DOM中首先接收到事件的元素。而且,我們知道this引用的是處理事件的DOM元素。
使用event.tatget屬性 明確事件對(duì)象
阻止事件冒泡的代碼如下:
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注