手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >事件委托与阻止冒泡阻止其父元素事件触发
事件委托与阻止冒泡阻止其父元素事件触发
摘要:简单说下事件委托与阻止冒泡html:全部纽约洛杉矶拉斯维加斯夏威夷旧金山奥兰多西雅图js:$("ul[data-type='cityPick...

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

html:

<ul data-type="cityPick"> <li 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被点击"); });

加一句阻止冒泡即可。

【事件委托与阻止冒泡阻止其父元素事件触发】相关文章:

JavaScript的RequireJS库入门指南

浅谈javascript事件取消和阻止冒泡

javascript结合Flexbox简单实现滑动拼图游戏

JavaScript中数组添加值和访问值常见问题

JS/Jquery判断对象为空的方法

Javascript中prototype属性实现给内置对象添加新的方法

JS和css实现检测移动设备方向的变化并判断横竖屏幕

js中跨域方法原理详解

JavaScript深度复制(deep clone)的实现方法

jQuery切换所有复选框选中状态的方法

精品推荐
分类导航