动态添加的标签,class属性无效(绑定事件不可用)

本文探讨了在动态添加控件时,如何正确地为这些控件绑定事件。传统的.click()方法仅适用于静态控件,对于动态添加的控件则无效。文章详细介绍了使用.on()方法来解决这一问题,确保动态添加的控件也能正常响应事件。

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

前面一篇文章提到动态添加、删除一行的实现方法

在项目中第一次写动态添加的时候,遇到了一个问题,就是添加的标签,之前绑定的同class事件都失效了,查资料后发现,是绑定事件使用的方法不对,下面说一下。


首先是失效情况

$('.btn').click(function() {
    alert('点击了按钮');
});

可以看到上面我是用.click()的方式绑定事件的,这个方法对动态添加的元素是无用的,只对静态控件有效。


下面是修改后实现的代码

$('body').on('click', '.btn', function() {
    alert('点击了按钮')
});

这里用的.on()方法来绑定,尝试后发现动态添加的按钮也绑定了事件。

总结:click()方法对动态生成的标签无效,当有动态控件时,可使用on()方法绑定事件。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值