最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

jquery阻止事件冒泡及其解决方法

来源:动视网 责编:小采 时间:2020-11-27 20:13:18
文档

jquery阻止事件冒泡及其解决方法

jquery阻止事件冒泡及其解决方法:动态添加标签的live事件注:jquery版本1.8之后不在支持live事件在实际项目中遇到的问题,动态添加的标签 live阻止冒泡失效,无论是用return false还是用e.stopPropagation()都不能阻止冒泡发生 以下是自己总结的例子html<p id="
推荐度:
导读jquery阻止事件冒泡及其解决方法:动态添加标签的live事件注:jquery版本1.8之后不在支持live事件在实际项目中遇到的问题,动态添加的标签 live阻止冒泡失效,无论是用return false还是用e.stopPropagation()都不能阻止冒泡发生 以下是自己总结的例子html<p id="


html
<p id="box"> 
 <a href="javascript:;" class="delete">init html</a>
</p> 
<button id="add">add html</button>
jq
 $(function() {

 // 用click事件
 $(document).click( function(event) {
 console.log('click');
 event.stopPropagation();
 });

 // 用delegate事件
 $(document).delegate('.delete','click', function(event) {
 console.log('delegate');
 event.stopPropagation();
 });

 // 用live事件
 $('.delete').live('click', function(event) {
 console.log('live');
 event.stopPropagation();
 //return false;
 });

 // 新添加的a标签
 $('#add').click(function() {
 var html = '<a href="javascript:;" class="delete">new html 1</a>';
 $('#box').append(html);
 });

 $('#box').click(function() {
 console.log('box emit');
 });

});

解决办法:
我们知道event.stopPropagation()对click阻止冒泡有效,那就可以在新动态添加的标签上绑定click事件。

文档

jquery阻止事件冒泡及其解决方法

jquery阻止事件冒泡及其解决方法:动态添加标签的live事件注:jquery版本1.8之后不在支持live事件在实际项目中遇到的问题,动态添加的标签 live阻止冒泡失效,无论是用return false还是用e.stopPropagation()都不能阻止冒泡发生 以下是自己总结的例子html<p id="
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top