亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JS中綁定事件順序(事件冒泡與事件捕獲區(qū)別)

 更新時(shí)間:2017年01月24日 14:19:40   作者:CboyDream  
本文主要介紹了JS中綁定事件順序(事件冒泡與事件捕獲區(qū)別)。具有很好的參考價(jià)值,下面跟著小編一起來看下吧

在JS中,綁定的事件默認(rèn)的執(zhí)行時(shí)間是在冒泡階段執(zhí)行,而非在捕獲階段(重要),這也是為什么當(dāng)父類和子類都綁定了某個(gè)事件,會(huì)先調(diào)用子類綁定的事件,后調(diào)用父類的事件。直接看下面實(shí)例

<!Doctype html>
<html>
<head>
 <meta charset="utf-8">
 <title></title>
 <style type="text/css">
 *{margin:0;padding: 0;}
 </style>
</head>
<body>
<div id="id1" style="height:400px; border:1px solid #000;">
 <div id="id2" style="height:200px; border:1px solid #000;">
 <div id="id3" style="height:50px; border:1px solid #000;"></div>
 </div>
</div>
</body>
<script type="text/javascript">
 var obj1=document.getElementById('id1'); 
 obj1.addEventListener('click',function(){
 alert('id1');
 },false);
 var obj2=document.getElementById('id2');
 obj2.addEventListener('click',function(){
 alert('id2');
 },true);
 var obj3=document.getElementById('id3');
 obj3.addEventListener('click',function(){
 alert('id3');
 },true);
 /*如果第三個(gè)參數(shù)為true,則事件在捕獲階段執(zhí)行,如果第三個(gè)參數(shù)為false,則事件在冒泡階段執(zhí)行*/
</script>
</html>

當(dāng)點(diǎn)擊id3元素時(shí)候,執(zhí)行結(jié)果是:id2,id3,id1

解析:因?yàn)閛bj2與obj3綁定的方法在捕獲階段執(zhí)行,obj1的事件在冒泡階段執(zhí)行。

總結(jié)

在JS中,綁定的事件默認(rèn)的執(zhí)行時(shí)間是在冒泡階段執(zhí)行,而非在捕獲階段,必須要理解

不過我們可以通過綁定事件時(shí),指定事件執(zhí)行時(shí)間是在冒泡階段還是捕獲階段。

obj.addEventListener(event,function(){},bool)

bool:false,代表冒泡階段執(zhí)行

bool:true,代表捕獲階段執(zhí)行

JS在默認(rèn)情況下獲取事件后,就開始從根元素開始捕獲所有該事件的監(jiān)聽對(duì)象,然后在冒泡階段逐一執(zhí)行。捕獲階段是在冒泡階段前面

阻止冒泡

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

阻止默認(rèn)行為

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

關(guān)于JS 事件冒泡和onclick,click,on()事件觸發(fā)順序

onclick,click,on()的優(yōu)先關(guān)系:onclick>click>on();

onclick和click綁定的事件,彼此之間遵守事件冒泡規(guī)則,從內(nèi)到外觸發(fā);

on()綁定的事件,總是晚于onclick和click綁定的事件觸發(fā);

以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時(shí)也希望多多支持腳本之家!

相關(guān)文章

最新評(píng)論