事件委托与阻止冒泡阻止其父元素事件触发
简单说下事件委托与阻止冒泡
html:
<ulclass="clearfix"data-type="cityPick"> <liclass="active_sort_opts"data-id="0">全部</li> <lidata-id="88">纽约</li> <lidata-id="119">洛杉矶</li> <lidata-id="138">拉斯维加斯</li> <lidata-id="84">夏威夷</li> <lidata-id="120">旧金山</li> <lidata-id="105">奥兰多</li> <lidata-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被点击");
});
加一句阻止冒泡即可。
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短