jquery阻止事件冒泡及解决办法 live

本文探讨了在jQuery中为动态添加的元素绑定点击事件时遇到的问题,特别是使用live事件时阻止冒泡行为失效的情况,并提供了可行的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

动态添加标签的live事件

注:jquery版本1.8之后不在支持live事件

在实际项目中遇到的问题,动态添加的标签
live阻止冒泡失效,无论是用return false还是用e.stopPropagation()都不能阻止冒泡发生
以下是自己总结的例子

html
<div id="box"> 
  <a href="javascript:;" class="delete">init html</a>
</div> 

<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事件。

大神们可畅所欲言,大家互相讨论;共同学习。
小Z(本人)自己总结的经验,有不足的地方请留言我修改。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值