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

首頁 > 開發 > JS > 正文

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

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

本文實例講述了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!')" href="http://www.baidu.com" 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();  });});

四、阻止冒泡的其他方法及不同

我就是用上面的函數阻止了冒泡,但是還有其他的方法可以達到類似的效果,但還是有所不同;

$("#alink").click(function(event) {  return false;});

解釋:上面方法使用jQuery對alink進行了操作,經過測試,得出結論,該函數阻止了冒泡,但是它將a的默認行為也屏蔽掉了(此處為href屬性)。這就是不同之處。

順便說下,javasccript的阻止默認行為的方法

event.preventDefault();

從上面可以看出,return false;event.stopPropagation();PreventDefault()的并集。

就到這里吧!

希望本文所述對大家JavaScript程序設計有所幫助。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 鄄城县| 榆树市| 仙游县| 信丰县| 武乡县| 故城县| 阳东县| 罗山县| 永济市| 炎陵县| 东源县| 乡城县| 金沙县| 改则县| 乐都县| 贵溪市| 平南县| 瑞丽市| 古田县| 岳池县| 桐城市| 阿拉善右旗| 永靖县| 平果县| 体育| 毕节市| 平山县| 昌邑市| 广汉市| 定远县| 乐安县| 沁水县| 漯河市| 通辽市| 墨竹工卡县| 深水埗区| 喜德县| 玛沁县| 武冈市| 夹江县| 应城市|