代理绑定和直接点击事件的区别

如果有大量动态生成的元素,普通的绑定方式会有很多不便,委托的方式有更好的性能和灵活性。因为可能你绑定的时候那个dom元素还没有生成,所以整个页面渲染完了之后,点击目标可能出不来识别不到点击事件( 以下代码用的是jquery写法)

<div class="button">nihao</div>
<span></span>

1、普通点击事件

 $('.button').click(function () {
        $('span').append('<div class="aa">aa</div>')
    });
    $('.aa').click(function () {
        alert($(this).text())
    })

此时点击aa是没有弹窗的,因为未绑定成功

2、代理绑定事件

$('.button').click(function () {
        $('span').append('<div class="aa">aa</div>')
    });
    $('span').on('click','.aa',function () {
        alert($(this).text())
    })

此时事件绑定成功,正常触发,有弹框。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值