JS冒泡事件的快速解決方法
何為冒泡事件
就是當設定了多個div的嵌套時;即建立了父子關系,當父div與子div共同加入了onclick事件時,當觸發(fā)了子div的onclick事件后,子div進行相應的js操作。但是父div的onclick事件同樣會被觸發(fā)。這就造成了事件的多層并發(fā),導致了頁面混亂。這就是冒泡事件。
消除冒泡事件的方法
阻止JavaScript事件冒泡傳遞(cancelBubble 、stopPropagation)
下面的一段代碼即可以很好的解釋是么是冒泡效果,什么叫消除冒泡效果
<html>
<head>
<title> 阻止JavaScript事件冒泡傳遞(cancelBubble 、stopPropagation)</title>
<meta name="keywords" content="JavaScript,事件冒泡,cancelBubble,stopPropagation" />
<script type="text/javascript">
function doSomething (obj,evt) {
alert(obj.id);
var e=(evt)?evt:window.event; //判斷瀏覽器的類型,在基于ie內核的瀏覽器中的使用cancelBubble
if (window.event) {
e.cancelBubble=true;
} else {
//e.preventDefault(); //在基于firefox內核的瀏覽器中支持做法stopPropagation
e.stopPropagation();
}
}
</script>
</head>
<body>
<div id="parent1" onclick="alert(this.id)" style="width:250px;background-color:yellow">
<p>This is parent1 div.</p>
<div id="child1" onclick="alert(this.id)" style="width:200px;background-color:orange">
<p>This is child1.</p>
</div>
<p>This is parent1 div.</p>
</div>
<br />
<div id="parent2" onclick="alert(this.id)" style="width:250px;background-color:cyan;">
<p>This is parent2 div.</p>
<div id="child2" onclick="doSomething(this,event);" style="width:200px;background-color:lightblue;">
<p>This is child2. Will bubble.</p>
</div>
<p>This is parent2 div.</p>
</div>
</body>
</html>
把代碼直接復制后,打開當點擊child1時不僅會彈出 child1 對話框還會彈出 parent1
這就是冒泡事件
但是單擊chile2只會彈出child2卻不會彈出 parent2,這便是應用了阻止冒泡事件的特效的效果.
- js之事件冒泡和事件捕獲詳細介紹
- js阻止默認事件與js阻止事件冒泡示例分享 js阻止冒泡事件
- javascript事件冒泡詳解和捕獲、阻止方法
- js冒泡、捕獲事件及阻止冒泡方法詳細總結
- js阻止冒泡及jquery阻止事件冒泡示例介紹
- zepto.js中tap事件阻止冒泡的實現方法
- js event事件的傳遞與冒泡處理
- JS阻止冒泡事件以及默認事件發(fā)生的簡單方法
- js如何取消事件冒泡
- js事件監(jiān)聽機制(事件捕獲)總結
- JavaScript 捕獲窗口關閉事件
- Javascript 事件捕獲的備忘(setCapture,captureEvents)
- JavaScript實現父子dom同時綁定兩個點擊事件,一個用捕獲,一個用冒泡時執(zhí)行順序的方法
相關文章
深入理解JavaScript系列(28):設計模式之工廠模式詳解
這篇文章主要介紹了深入理解JavaScript系列(28):設計模式之工廠模式詳解,工廠模式定義一個用于創(chuàng)建對象的接口,這個接口由子類決定實例化哪一個類,需要的朋友可以參考下2015-03-03微信小程序MUI側滑導航菜單示例(Popup彈出式,左側滑動,右側不動)
這篇文章主要介紹了微信小程序MUI側滑導航菜單,結合實例形式分析了微信小程序Popup彈出式,左側滑動,右側不動菜單功能相關實現技巧與注意事項,需要的朋友可以參考下2019-01-01javascript當onmousedown、onmouseup、onclick同時應用于同一個標簽節(jié)點Element
先通過一個簡單例子測試并發(fā)現我說的問題,讓你有個直觀的印象,再接著看我的解決辦法。2010-01-01