事件委托与阻止冒泡

时间 : 14-08-30 栏目 : 前端开发 作者 : 冰镇宝贝321 评论 : 0 点击 : 1,905 次

简单说下事件委托与阻止冒泡

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的事件也被触发了,这是我们不想看到的。

================================================================

解决:

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

 

加一句阻止冒泡即可。



本文标签 ,

除非注明,文章均为( 冰镇宝贝321 )原创,转载请保留链接: https://bkqv5.com/archives/67.html

事件委托与阻止冒泡:等您坐沙发呢!

发表评论




0