国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

js冒泡、捕獲事件及阻止冒泡方法詳細總結

2024-05-06 16:05:32
字體:
來源:轉載
供稿:網友
javascript, jquery的事件中都存在事件冒泡和事件捕獲的問題,針對這兩個問題,本文給出詳細的解決方法,需要的朋友不要錯過

javascript, jquery的事件中都存在事件冒泡和事件捕獲的問題,下面將兩種問題及其解決方案做詳細總結。

事件冒泡是一個從子節點向祖先節點冒泡的過程;

事件捕獲剛好相反,是從祖先節點到子節點的過程。

給一個jquery點擊事件的例子:

代碼如下:

復制代碼 代碼如下:


<!DOCTYPE html>
<meta charset="utf-8">
<title>test</title>
<head>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<script type="text/javascript">
$(function(){
$('#clickMe').click(function(){
alert('hello');
});
$('body').click(function(){
alert('baby');
});
});
</script>
</head>
<body>
<div>
<button type="button">click me</button>
<button>click</button>
</div>
</body>
</html>


事件冒泡現象:點擊 “id=clickMe” 的button,會先后出現“hello” 和 “baby” 兩個彈出框。

分析:當點擊 “id=clickMe” 的button時,觸發了綁定在button 和 button 父元素及body的點擊事件,所以先后彈出兩個框,出現所謂的冒泡現象。


事件捕獲現象:點擊沒有綁定點擊事件的div和 “id=button2” 的button, 都會彈出 “baby” 的對話框。


在實際的項目中,我們要阻止事件冒泡和事件捕獲現象。

阻止事件冒泡方法:

法1:當前點擊事件中return false;

復制代碼 代碼如下:


$('#clickMe').click(function(){
alert('hello');

return false;
});


法2:

復制代碼 代碼如下:


$('#clickMe').click(function(event){
alert('hello');

var e = window.event || event;

if ( e.stopPropagation ){ //如果提供了事件對象,則這是一個非IE瀏覽器
e.stopPropagation();
}else{
//兼容IE的方式來取消事件冒泡
window.event.cancelBubble = true;
}
});


貌似捕獲事件不能被阻止
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 娱乐| 和顺县| 安图县| 惠东县| 保定市| 西乌| 张家港市| 温州市| 新津县| 鄱阳县| 漠河县| 榕江县| 昔阳县| 莆田市| 漳州市| 孟津县| 尤溪县| 康保县| 靖安县| 永丰县| 沈阳市| 务川| 商水县| 如东县| 静海县| 陆川县| 交口县| 大邑县| 绥阳县| 孙吴县| 固始县| 凤冈县| 天门市| 合山市| 布尔津县| 大埔区| 秭归县| 蚌埠市| 金坛市| 江达县| 克什克腾旗|