JS的事件冒泡和事件捕获

事件冒泡&捕获

JS在默认情况下冒泡执行事件,就开始从根元素开始捕获所有该事件的监听对象。我们可以通过绑定事件时,指定事件执行时在冒泡阶段还是捕获阶段。

obj.addEventListener(event,function(){},bool);
bool:false,代表冒泡阶段执行
bool:true,代表捕获阶段执行

Example:

    <ul>
            <li>item1</li>
            <li>item2</li>
            <li>item3</li>
            <li>item4</li>
            <li>item5</li>
            <li>item6</li>
        </ul>

譬如有ul事件和li事件,点击li后

事件捕获

自上而下的去触发事件,先触发ul事件,再触发li事件

document.getElementById("parentId").addEventListener("click",function(e){
    alert('****** Trigger parent event ******');
}, true);

事件冒泡

自下而上的去触发事件,先触发li事件,再触发ul事件

阻止事件冒泡

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

<script type="text/javascript">  
    var obj1=document.getElementById('id1');   
    obj1.addEventListener('click',function(e){curClick('id1');stopPropagation(e)},false);  

    var obj2=document.getElementById('id2');  
    obj2.addEventListener('click',function(e){curClick('id2');stopPropagation(e)},true);  

    var obj3=document.getElementById('id3');  
    obj3.addEventListener('click',function(e){curClick('id3');stopPropagation(e)},true);  

    function curClick(id){  
        alert(id);  
    }  

    function  stopPropagation(e){  
        var e = window.event || event;    
        if(e.stopPropagation) { //W3C阻止冒泡方法    
            e.stopPropagation();    
        } else {    
            e.cancelBubble = true; //IE阻止冒泡方法    
        }   
    }      
</script>  

当点击id3:执行结果:id2
当点击id2:执行结果:id2
当点击id1:执行结果:id1
通过这个例子发现,原来阻止了事件冒泡,也阻止了事件继续向下级捕获。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值