欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript事件冒泡機(jī)制原理實(shí)例解析

 更新時(shí)間:2020年01月14日 10:59:57   作者:smileNicky  
這篇文章主要介紹了JavaScript事件冒泡機(jī)制原理實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

這篇文章主要介紹了JavaScript事件冒泡機(jī)制原理實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

DOM事件流(event flow )存在三個(gè)階段:事件捕獲階段、處于目標(biāo)階段、事件冒泡階段,事件冒泡順序是由內(nèi)到外進(jìn)行事件傳播,事件冒泡是由IE開發(fā)團(tuán)隊(duì)提出來的,即事件開始時(shí)由最具體的元素(文檔中嵌套層次最深的那個(gè)節(jié)點(diǎn))接收,然后逐級(jí)向上傳播。

聽了簡(jiǎn)介介紹之后,您可能不理解,所以舉個(gè)例子:

<html>
<head>
<title>js事件冒泡測(cè)試</title>
</head>
<body>
<div id='content' onclick='alert("content")'>
<div id='div' onclick='alert("div");'>
<ul onclick='alert("ul");'>
<li onclick='alert("li");'>test</li>
</ul>
</div>
</div>
</body>
</html>

點(diǎn)擊test頁簽,會(huì)依次執(zhí)行l(wèi)i的onclick、ul的onclick、div的onclick,content的onclick,從內(nèi)到外執(zhí)行,所以這個(gè)就是冒泡事件的簡(jiǎn)單例子

最近也遇到了這種情況,所以就去網(wǎng)上搜索資料,簡(jiǎn)單學(xué)習(xí)一下,就是點(diǎn)擊一個(gè)按鈕的時(shí)候,竟然觸發(fā)了兩次,通過排查,發(fā)現(xiàn)了冒泡機(jī)制導(dǎo)致的,解決方法是禁用事件冒泡機(jī)制

w3c的方法是e.stopPropagation(),IE則是使用e.cancelBubble = true

$(element).click(function(e){
  e.stopPropagation();//ie e.cancelBubble = true
});

當(dāng)然除了冒泡機(jī)制會(huì)導(dǎo)致onclick被調(diào)用兩次外,事件被綁定2次的情況也有可能,解決方法是解除事件,然后再綁定

$(element).unbind('click').click(function() {
    // todo  
})

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論