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

首頁 > 語言 > JavaScript > 正文

JavaScript捕捉事件和阻止冒泡事件實例分析

2024-05-06 15:32:09
字體:
來源:轉載
供稿:網友

本文實例講述了JavaScript捕捉事件和阻止冒泡事件。分享給大家供大家參考,具體如下:

今日,項目程序出現異常,后發現跟冒泡事件有關,利用此機會探索一下利用Javascript捕獲和冒泡事件。

一、要探究捕獲和冒泡事件,首先要知道什么是事件的捕獲和冒泡,所以呢,先從概念入手;

事件的冒泡:在一個對象上觸發某類事件(比如單擊onclick事件),如果此對象定義了此事件的處理程序,那么此事件就會調用這個處理程序,如果沒有定義此事件處理程序或者事件返回true,那么這個事件會向這個對象的父級對象傳播,從里到外,直至它被處理(父級對象所有同類事件都將被激活),或者它到達了對象層次的最頂層,即document對象(有些瀏覽器是window)。

其實事件冒泡是一個從后代節點向祖先節點冒泡的過程,而捕獲是從祖先節點到后節點的過程。

我為了方便理解,則用先捕獲,后冒泡,捕獲從上到下,冒泡從下到上來記憶。我記得從哪兒看到的,有人把捕獲比喻為石頭沉入海底,而把冒泡比喻為氣泡冒出水面。當然了,捕獲的深度取決于你的DOM布局,海底就有點深了哈,^_^

注意:IE6、IE7、IE8只支持冒泡流,不支持捕獲流。

二、為什么要阻止冒泡事件

也許會有人問:為什么要阻止冒泡事件呢?阻止冒泡事件有什么用處呢?

下面我們就來說下為什么要阻止冒泡事件:

先舉個例子吧,如下代碼:

<html>  <div id='div_1' onclick="alert('I'm First!')">     <div id='div_2' onclick="alert('I'm Second!')">         <a id="alink" onclick="alert('I'm Third!')"  rel="external nofollow" >Click Here</a>     </div>  </div></html>

從上面的代碼可以看出,div_1是div_2的容器,而div_2是a的容器,總共三層。

我們運行這個實例,點擊Click Here會發現,分別彈出了三個alert提示框,而且順序為I'm Third! 、I'm Second!、I'm First!,這就符合我們上面提到的冒泡的概念了。

而我這次碰到的問題就是這樣,我稱之為“事件重疊”。

出現這種情況,肯定不行,所以我們要阻止該事件冒泡的發生,那如何來阻止呢?下面將。

三、阻止事件冒泡的方法

首先我先給出一個純JavaScript版的寫法:

function aOnClick(e){   window.event? window.event.cancelBubble = true : e.stopPropagation();}

解釋:因為IE里的阻止冒泡的寫法為window.event.cancelBubble = true,其他瀏覽器為e.stopPropagation();所以這里做了兼容。

再給出一個jQuery版本的寫法:

$(function() {  $("#alink").click(function(event) {    event.stopPropagation();  });});            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 新闻| 子洲县| 牟定县| 乌苏市| 忻城县| 乐业县| 遂宁市| 临汾市| 美姑县| 浮梁县| 济宁市| 太和县| 桂东县| 日照市| 凌海市| 河东区| 九龙城区| 马龙县| 嘉祥县| 兰西县| 科尔| 呼伦贝尔市| 调兵山市| 神木县| 鄯善县| 龙游县| 横峰县| 闸北区| 常州市| 铜鼓县| 来安县| 连南| 晋宁县| 富蕴县| 红河县| 开化县| 瑞金市| 蒙自县| 庄河市| 红原县| 精河县|