阻止冒泡和取消默認(rèn)事件

  1. 冒泡型事件(從小到大)
<div id='div' onclick='alert("div");'>
<ul onclick='alert("ul");'>
<li onclick='alert("li");'>test</li>
</ul>
</div>

//單擊test時(shí),會(huì)依次觸發(fā)alert(“l(fā)i”),alert(“ul”),alert(“div”)忠售,這就是事件冒泡铆隘。
  1. 抓捕型事件(從大到械缳鳌)
阻止冒泡

w3c的方法是e.stopPropagation(),IE則是使用e.cancelBubble = true

window.event? window.event.cancelBubble = true : e.stopPropagation();
取消默認(rèn)事件

w3c的方法是e.preventDefault()但绕,IE則是使用e.returnValue = false

    <body>
        <a id='aa' >盡管點(diǎn)擊跛梗,我也不會(huì)跳轉(zhuǎn)</a>
        <script>
            var a = document.getElementById('aa');
            console.log('a',a)
            a.onclick = function(e) {
                if(e.preventDefault){
                    e.preventDefault();
                }else{
                    window.event.returnValue == false
                }
            }

        </script>
    </body>

return false

javascript的return false只會(huì)阻止默認(rèn)行為寻馏,而是用jQuery的話則既阻止默認(rèn)行為又防止對(duì)象冒泡。·

原生js用return false

<div id='div'  onclick='alert("div");'>
<ul  onclick='alert("ul");'>
<li id='ul-a' onclick='alert("li");'><a >caibaojian.com</a></li>
</ul>
</div>
var a = document.getElementById("testB");
a.onclick = function(){
return false;
};

如上核偿,只取消默認(rèn)事件诚欠,但不取消冒泡事件。

jQuery使用return false

<div id='div'  onclick='alert("div");'>
<ul  onclick='alert("ul");'>
<li id='ul-a' onclick='alert("li");'><a >caibaojian.com</a></li>
</ul>
</div>
$("#testC").on('click',function(){
return false;
});

如上漾岳,即取消默認(rèn)事件轰绵,又取消冒泡事件

總結(jié)使用方法
當(dāng)需要停止冒泡行為時(shí),可以使用

function stopBubble(e) { 
//如果提供了事件對(duì)象尼荆,則這是一個(gè)非IE瀏覽器 
if ( e && e.stopPropagation ) 
    //因此它支持W3C的stopPropagation()方法 
    e.stopPropagation(); 
else 
    //否則左腔,我們需要使用IE的方式來(lái)取消事件冒泡 
    window.event.cancelBubble = true; 
}

當(dāng)需要阻止默認(rèn)行為時(shí),可以使用

//阻止瀏覽器的默認(rèn)行為 
function stopDefault( e ) { 
    //阻止默認(rèn)瀏覽器動(dòng)作(W3C) 
    if ( e && e.preventDefault ) 
        e.preventDefault(); 
    //IE中阻止函數(shù)器默認(rèn)動(dòng)作的方式 
    else 
        window.event.returnValue = false; 
    return false; 
}

來(lái)源:前端開(kāi)發(fā)博客

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末捅儒,一起剝皮案震驚了整個(gè)濱河市液样,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌巧还,老刑警劉巖鞭莽,帶你破解...
    沈念sama閱讀 221,273評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異麸祷,居然都是意外死亡澎怒,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門阶牍,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)喷面,“玉大人,你說(shuō)我怎么就攤上這事走孽【灞玻” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 167,709評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵磕瓷,是天一觀的道長(zhǎng)盒齿。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么县昂? 我笑而不...
    開(kāi)封第一講書人閱讀 59,520評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮陷舅,結(jié)果婚禮上倒彰,老公的妹妹穿的比我還像新娘。我一直安慰自己莱睁,他們只是感情好待讳,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著仰剿,像睡著了一般创淡。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上南吮,一...
    開(kāi)封第一講書人閱讀 52,158評(píng)論 1 308
  • 那天琳彩,我揣著相機(jī)與錄音,去河邊找鬼部凑。 笑死露乏,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的涂邀。 我是一名探鬼主播瘟仿,決...
    沈念sama閱讀 40,755評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼比勉!你這毒婦竟也來(lái)了劳较?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,660評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤浩聋,失蹤者是張志新(化名)和其女友劉穎观蜗,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體赡勘,經(jīng)...
    沈念sama閱讀 46,203評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡嫂便,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了闸与。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片毙替。...
    茶點(diǎn)故事閱讀 40,427評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖践樱,靈堂內(nèi)的尸體忽然破棺而出厂画,到底是詐尸還是另有隱情,我是刑警寧澤拷邢,帶...
    沈念sama閱讀 36,122評(píng)論 5 349
  • 正文 年R本政府宣布袱院,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏忽洛。R本人自食惡果不足惜腻惠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望欲虚。 院中可真熱鬧集灌,春花似錦、人聲如沸复哆。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,272評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)梯找。三九已至唆阿,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間锈锤,已是汗流浹背驯鳖。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,393評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留牙咏,地道東北人臼隔。 一個(gè)月前我還...
    沈念sama閱讀 48,808評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像妄壶,于是被迫代替她去往敵國(guó)和親摔握。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評(píng)論 2 359