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

html:

<ul class="clearfix" data-type="cityPick">
						<li class="active_sort_opts" data->全部</li>
						<li data->纽约</li>
						<li data->洛杉矶</li>
						<li data->拉斯维加斯</li>
						<li data->夏威夷</li>
						<li data->旧金山</li>
						<li data->奥兰多</li>
						<li data->西雅图</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被点击");
});


加一句阻止冒泡即可。


更多讲解与优秀文章:http://www.ituring.com.cn/article/467#


相关文章:

  • 2021-10-01
  • 2021-06-04
猜你喜欢
  • 2022-02-28
  • 2021-06-21
  • 2022-12-23
  • 2021-12-17
  • 2022-12-23
  • 2021-08-29
相关资源
相似解决方案