stoppropagation月弛、cancelBubble區(qū)別(阻止冒泡)

事實上stoppropagation和cancelBubble的作用是一樣的胧后,都是用來阻止瀏覽器默認的事件冒泡行為芋浮。

不同之處在于stoppropagation屬于W3C標準,試用于Firefox等瀏覽器壳快,但是不支持IE瀏覽器纸巷。相反cancelBubble不符合W3C標準,而且只支持IE瀏覽器眶痰。所以很多時候瘤旨,我們都要結合起來用。不過凛驮,cancelBubble在新版本chrome,opera瀏覽器中已經(jīng)支持裆站。

語法:e.stopPropagation();

參數(shù)e:表示事件傳遞的參數(shù),代表事件的狀態(tài)黔夭。
[html] view plain copy

    <html>  
    <head>  
        <title>冒泡測試</title>  
    </head>  
    <body onclick="alert('body');">  
      
        <div onclick="clickBtn(event)"  style="width:100px;height:100px; background:#666;">  
            <input id="Button1" type="button" value="button" onclick="alert('btn');" />  
        </div>  
        <script language="javascript" type="text/javascript">  
            function clickBtn(event)  
            {  
                event=event?event:window.event;  
                event.stopPropagation();  
                alert("OK");  
            }  
        </script>  
    </body>  
    </html> 

阻止事件冒泡stopPropagation的兼容寫法

function stopPropagation(e){
    e=window.event||e;
    if(document.all){  //只有ie識別
        e.cancelBubble=true;
    }else{
        e.stopPropagation();
    }
}

cancelBubble 檢測是否接受上層元素的事件的控制宏胯。

語法: event.cancelBubble[ = cancelBubble]
可能的值: 這是一個可讀寫的布爾值:
true 不被上層元素的事件控制。
false 允許被上層元素的事件控制本姥。這是默認值肩袍。

事件捕獲其實有三種方式,事件冒泡只是其中的一種:

(1)IE從里到外(inside→outside)的冒泡型事件婚惫。
(2)Netscape4.0從外到里(outside→inside)的捕獲型事件氛赐。
(3)DOM事件流魂爪,先從外到里,再從里到外回到原點(outside→inside→outside)的事件捕獲方法艰管。

不是所有的事件都能冒泡滓侍。以下事件不冒泡:blur、focus牲芋、load撩笆、unload。

事件捕獲方式在不同瀏覽器缸浦,甚至同種瀏覽器的不同版本中是有所區(qū)別的夕冲。如Netscape4.0采用捕獲型事件解決方案,其它多數(shù)瀏覽器則支持冒泡型事件解決方案裂逐,另外DOM事件流還支持文本節(jié)點事件冒泡歹鱼。

事件捕獲到達頂層的目標在不同瀏覽器或不同瀏覽器版本也是有區(qū)別的。在IE6中HTML是接收事件冒泡的卜高,另外大部分瀏覽器將冒泡延續(xù)到window對象弥姻,即……body→documen→window。

阻止冒泡并不能阻止對象默認行為篙悯。比如submit按鈕被點擊后會提交表單數(shù)據(jù)蚁阳,這種行為無須我們寫程序定制。

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末鸽照,一起剝皮案震驚了整個濱河市螺捐,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌矮燎,老刑警劉巖定血,帶你破解...
    沈念sama閱讀 219,188評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異诞外,居然都是意外死亡澜沟,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評論 3 395
  • 文/潘曉璐 我一進店門峡谊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來茫虽,“玉大人,你說我怎么就攤上這事既们”粑觯” “怎么了?”我有些...
    開封第一講書人閱讀 165,562評論 0 356
  • 文/不壞的土叔 我叫張陵啥纸,是天一觀的道長号杏。 經(jīng)常有香客問我,道長斯棒,這世上最難降的妖魔是什么盾致? 我笑而不...
    開封第一講書人閱讀 58,893評論 1 295
  • 正文 為了忘掉前任主经,我火速辦了婚禮,結果婚禮上庭惜,老公的妹妹穿的比我還像新娘罩驻。我一直安慰自己,他們只是感情好蜈块,可當我...
    茶點故事閱讀 67,917評論 6 392
  • 文/花漫 我一把揭開白布鉴腻。 她就那樣靜靜地躺著,像睡著了一般百揭。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蜓席,一...
    開封第一講書人閱讀 51,708評論 1 305
  • 那天器一,我揣著相機與錄音,去河邊找鬼厨内。 笑死祈秕,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的雏胃。 我是一名探鬼主播请毛,決...
    沈念sama閱讀 40,430評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼瞭亮!你這毒婦竟也來了方仿?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,342評論 0 276
  • 序言:老撾萬榮一對情侶失蹤统翩,失蹤者是張志新(化名)和其女友劉穎仙蚜,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體厂汗,經(jīng)...
    沈念sama閱讀 45,801評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡委粉,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,976評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了娶桦。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片贾节。...
    茶點故事閱讀 40,115評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖衷畦,靈堂內(nèi)的尸體忽然破棺而出栗涂,到底是詐尸還是另有隱情,我是刑警寧澤霎匈,帶...
    沈念sama閱讀 35,804評論 5 346
  • 正文 年R本政府宣布戴差,位于F島的核電站,受9級特大地震影響铛嘱,放射性物質發(fā)生泄漏暖释。R本人自食惡果不足惜袭厂,卻給世界環(huán)境...
    茶點故事閱讀 41,458評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望球匕。 院中可真熱鬧纹磺,春花似錦、人聲如沸亮曹。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽照卦。三九已至式矫,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間役耕,已是汗流浹背采转。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留瞬痘,地道東北人故慈。 一個月前我還...
    沈念sama閱讀 48,365評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像框全,于是被迫代替她去往敵國和親察绷。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,055評論 2 355