JS事件冒泡和事件委托

js事件冒泡

js所谓的事件冒泡就是子级元素的某个事件被触发,它的上级元素的该事件也被递归执行

html:

 

复制代码

<ul class="clearfix" data-type="cityPick"> 
    <li class="active_sort_opts" data-id="0">全部</li> 
    <li data-id="88">纽约</li> 
    <li data-id="119">洛杉矶</li> 
    <li data-id="138">拉斯维加斯</li> 
    <li data-id="84">夏威夷</li> 
    <li data-id="120">旧金山</li> 
    <li data-id="105">奥兰多</li> 
    <li data-id="118">西雅图</li> 
</ul>

复制代码

 

js:

$("ul[data-type='cityPick']").on('click',function(){ 
    alert("父元素ul被点击"); 
}); 
$("ul[data-type='cityPick']").on('click','li',function(){ 
    alert("子元素li被点击"); 
});

当li的点击事件被触发时,父级ul的点击事件也被触发执行了,

而在某些场合我们是不希望它冒泡的,怎么做呢? 简单!

js:

复制代码

$("ul[data-type='cityPick']").on('click',function(){ 
    alert("父元素ul被点击"); 
}); 
$("ul[data-type='cityPick']").on('click','li',function(e){ 
    e.stopPropagation();//阻止冒泡 
    alert("子元素li被点击"); 
});

复制代码

加上e.stopPropagation(); 这一句便可以阻止事件冒泡了

js事件委托
js事件委托,其实是使用了冒泡的原理,从点击的元素开始,递归方式的向父元素传播事件,这样做的好处是对于大量要处理的元素,不必为每个元素都绑定事件,只需要在他们的父元素上绑定一次即可,提高性能。 还有一个好处就是可以处理动态插入dom中的元素,直接绑定的方式是不行的。
就是事件目标自身不处理事件,而是把处理任务委托给其父元素或者祖先元素,甚至根元素事件委托很好地利用了"事件冒泡"。当点击子元素,根据"事件冒泡",该子元素的父级元素捕获了该次点击事件,并触发自己的方法。
看实例:
假如现在有10个按钮,要为每个按钮绑定一个click事件,可能才十个按钮,你可以一个一个的绑定或用循环进行绑定,但是这样性能呢?
html:

复制代码

<div class="button-group">
        <bottoun type="button" class="btn">提交</bottoun>
        <bottoun type="button" class="btn">提交</bottoun>
        <bottoun type="button" class="btn">提交</bottoun>
        <bottoun type="button" class="btn">提交</bottoun>
        <bottoun type="button" class="btn">提交</bottoun>
        <bottoun type="button" class="btn">提交</bottoun>
        <bottoun type="button" class="btn">提交</bottoun>
        <bottoun type="button" class="btn">提交</bottoun>
        <bottoun type="button" class="btn">提交</bottoun>
        <bottoun type="button" class="btn">提交</bottoun>
    </div>

复制代码

js:

$(".button-group").on('click','.btn',function(){
      alert($(this).html());
});

这里可以看出,我们只是为所有的button的一个父级绑定了click事件,而不是为所有的button绑定事件,极大的提高了性能,这样做的好处还有可以对动态加进来的元素进行处理

就是有一个按钮原本的dom里面是没有的,是你通过其他方式添加进来的,即未来元素,用直接绑定方法是不能成功的,只能用事件委托,委托给该元素的父级进行处理

由于事件委托是通过事件冒泡实现的,所以如果子级的元素阻止了事件冒泡,那么事件委托也将失效!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值