第一種event.stopPropagation(); 阻止事件冒泡
岳西網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)建站,岳西網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為岳西1000+提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)營銷網(wǎng)站建設(shè)要多少錢,請找那個售后服務(wù)好的岳西做網(wǎng)站的公司定做!
第二種event.preventDefault() 阻止默認(rèn)事件的冒泡
阻止事件冒泡可以防止觸發(fā)父元素上面綁定的事件。
比如:
div?class="parent"
div?class="child"123/div
1234
/div在parnet上面和child上面都綁定click事件,并且打印1234,當(dāng)你點擊child的div時,會發(fā)現(xiàn)打印兩次。
什么是事件冒泡:在一個對象上觸發(fā)某類事件(比如onclick事件),如果次對象定義了此事件的處理程序,那么此事件就會調(diào)用這個處理程序,如果沒有定義此事件處理程序或者事件返回true,那么這個事件會向這個對象的父級對象傳播,從里到外,直至它被處理(父級對象所有同類事件都將被激活),或者它到達(dá)了對象層次的最頂層,即document對象(有些瀏覽器是window)。
事件冒泡的作用:事件冒泡允許多個操作被集中處理(把事件處理器添加到一個父級元素上,避免把事件處理器添加到多個子級元素上),它還可以讓你在對象層的不同級別捕獲事件。
阻止事件冒泡:事件冒泡機(jī)制有時候是不需要的,需要阻止掉,通過 event.stopPropagation() 來阻止
$(function(){
})
代合并阻止操作:實際開發(fā)中,一般把阻止冒泡和阻止默認(rèn)行為合并起來寫,合并寫法可以用.
// event.stopPropagation();
// event.preventDefault();
// 合并寫法:
return false;
事件委托就是利用冒泡的原理,把事件加到父級上,通過判斷事件來源的子集,執(zhí)行相應(yīng)的操作,事件委托首先可以極大減少事件綁定次數(shù),提高性能;其次可以讓新加入的子元素也可以擁有相同的操作。
一般綁定事件的寫法:bind
事件委托的寫法:
如果我們要取消事件的委托:
//ev.delegateTarge 委托的對象
$(ev.delegateTarge).undelegatee();
//如果是上面的兩種例子可使用//$list.undelegate();
創(chuàng)建節(jié)點: ('div')
var ('div這是一個div元素/div');
插入節(jié)點:
1、append()和appendTo():在現(xiàn)存元素的內(nèi)部,從后面插入元素
2、prepend()和prependTo():在現(xiàn)存元素的內(nèi)部,從前面插入元素
3、after()和insertAfter():在現(xiàn)存元素的外部,從后面插入元素
4、before()和insertBefore():在現(xiàn)存元素的外部,從前面插入元素
刪除節(jié)點
$('#div1').remove();
事件冒泡:開始時由最具體的元素接收,然后逐級向上傳播到到 DOM 最頂層節(jié)點。
1.標(biāo)準(zhǔn)寫法:利用事件對象里面的 stopPropagation()方法
e.stopPropagation()
2.非標(biāo)準(zhǔn)寫法:IE 6-8 利用事件對象 cancelBubble 屬性
e.cancelBubble = true;
事件委托也稱為事件代理, 在 jQuery 里面稱為事件委派。 不是每個子節(jié)點單獨(dú)設(shè)置事件監(jiān)聽器,而是事件監(jiān)聽器設(shè)置在其父節(jié)點上,然后利用冒泡原理影響設(shè)置每個子節(jié)點。
如:給 ul 注冊點擊事件,然后利用事件對象的 target 來找到當(dāng)前點擊的 li,因為點擊 li,事件會冒泡到 ul 上,ul 有注冊事件,就會觸發(fā)事件監(jiān)聽器,這里只操作了一次 DOM ,提高了程序的性能。
在火狐Firefox、opera、IE下阻止冒泡事件是不同的代碼的,火狐下使用的是event.stopPropagation(),而IE下使用的是cancelBubble,jQuery 可以使用e.stopPropagation()就可以兼容了,如果是純粹的JavaScript需要下面的代碼來統(tǒng)一:
if (event.stopPropagation) {
// this code is for Mozilla and Opera
event.stopPropagation();
}
else if (window.event) {
// this code is for IE
window.event.cancelBubble = true;
}
-
(1)什么是事件起泡
首先你要明白一點,當(dāng)一個事件發(fā)生的時候,該事件總是有一個事件源,即引發(fā)這個事件的對象,一個事件不能憑空產(chǎn)生,這就是事件的發(fā)生。
當(dāng)事件發(fā)生后,這個事件就要開始傳播。為什么要傳播呢?因為事件源本身并沒有處理事件的能力。例如我們點擊一個按鈕時,就會產(chǎn)生一個click事件,但這個按鈕本身不能處理這個事件(廢話),事件必須從這個按鈕傳播出去,從而到達(dá)能夠處理這個事件的代碼中(例如我們給按鈕的onclick屬性賦一個函數(shù)的名字,就是讓這個函數(shù)去處理該按鈕的click事件)。
當(dāng)事件在傳播過程中,找到了一個能夠處理它的函數(shù),這時候我們就說這個函數(shù)捕捉到了這個事件。
說到這里,關(guān)鍵的問題來了,那就是一個函數(shù)是如何捕捉一個事件的呢?這就涉及到事件的冒泡了。
為了更好地理解冒泡的概念,我建議你現(xiàn)在想象一下你的面前放著一杯水,但這杯水和我們平時看到的有點點不同,它分為數(shù)層,每一層又分成一或多個區(qū)域,最頂層是我們熟悉的窗口對象(即window對象),下一層分為好幾個區(qū)域(document對象、history對象等等),而document對象的下一層又分為多個子對象。
這些對象的層次關(guān)系構(gòu)成了DOM中的對象樹。
事件的傳播是有方向的,當(dāng)點擊一個按鈕時所產(chǎn)生的事件從這個按鈕處開始向上傳播(就像一個水泡從杯底冒上來,這就是之所以叫事件冒泡的原因),但這個事件總是尋找特定的屬性是否有值。例如按鈕的click事件先尋找在按鈕上是否有onclick屬性的有意義的定義(即該屬性指向一個存在的函數(shù)或一段可執(zhí)行的語句),如果有,執(zhí)行這個函數(shù)或語句;然后事件繼續(xù)向上傳播,到達(dá)按鈕的上一層對象(例如一個form對象或document對象,總之是包含了按鈕的父對象),如果該對象也定義了onclick屬性,則執(zhí)行屬性的值。
所以,如果這個按鈕上面有3層(form、document、window),且這三層都定義了onclick屬性,則當(dāng)按鈕的click事件產(chǎn)生時,將會調(diào)用4個(包括按鈕本身的一個)函數(shù)或執(zhí)行4段語句。
事件的這幾個特性在0級dom中也是適用的。
(2)jquery阻止事件起泡實例
1、通過返回false來取消默認(rèn)的行為并阻止事件起泡。
jQuery 代碼:
復(fù)制代碼 代碼如下:
$("form").bind(
"submit",
function() {
return false;
}
);
2、通過使用 preventDefault() 方法只取消默認(rèn)的行為。
jQuery 代碼:
復(fù)制代碼 代碼如下:
$("form").bind(
"submit",
function(event){
event.preventDefault();
}
);
3、通過使用 stopPropagation() 方法只阻止一個事件起泡。
jQuery 代碼:
復(fù)制代碼 代碼如下:
$("form").bind(
"submit",
function(event){
event.stopPropagation();
}
);
(3)關(guān)于js事件起泡的驗證
今天這個問題主要涉及到幾個關(guān)鍵詞:對象,觸發(fā)事件,捕獲事件,執(zhí)行處理、起泡。這其實就是整個js執(zhí)行的過程。其中冒泡這個過程很有意思。其實就像是一杯水,但是這杯水是分層次的,最底下是當(dāng)前觸發(fā)事件的對象。然后越往上范圍越大,最頂層肯定是window,倒數(shù)第二層是document。氣泡在上浮過程中會判斷當(dāng)前所到達(dá)的層有沒有綁定事件處理方法。有話就執(zhí)行相應(yīng)的處理。沒有的話就繼續(xù)起泡。直到到達(dá)最頂層的window窗口層。我們可以在任何一層做相應(yīng)的處理以阻止事件繼續(xù)起泡。方法就是調(diào)用事件對象的阻止起泡的方法。event.stopPropagation();下面是寫的一個驗證js事件起泡的過程方法。
復(fù)制代碼 代碼如下:
script type="text/javascript"
$(document).ready(function(){
$('.one').click(function(e){
alert('one');
});
$('.two').click(function(e){
alert('two');
});
$('.three').click(function(e){
alert('three');
//阻止起泡取消下面的注釋
// e.stopPropagation();
});
});
/script
div class="one" style="width:200px;height:200px;background:green;"
one
div class="two" style="width:150px;height:150px;background:yellow;"
two
div class="three"
three
/div
/div
/div
(4)總結(jié)
1.一個事件起泡對應(yīng)觸發(fā)的是上層的同一事件
特殊:如果two設(shè)置成雙擊事件,那么在你單擊two的時候就會起泡觸發(fā)one單擊的事件
(雙擊包含單擊)。
2.如果在click事件中,在你要處理的事件之前加上e.preventDefault();
那么就取消了行為(通俗理解:相當(dāng)于做了個return操作),不執(zhí)行之后的語句了。
3.e.stopPropagation()只要在click事件中,就不會觸發(fā)上層click事件。
網(wǎng)頁標(biāo)題:jquery阻止事件冒泡,js阻止冒泡事件
標(biāo)題URL:http://jinyejixie.com/article18/dssosdp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供服務(wù)器托管、虛擬主機(jī)、關(guān)鍵詞優(yōu)化、自適應(yīng)網(wǎng)站、微信小程序、域名注冊
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)