解决jquery动态创建元素绑定事件失效问题

存在问题

在我们使用jquery动态创建元素后往往会遇到一些问题,如:

给.button按钮绑定了点击时间,执行alert:(1);

 

 点击事件代码如下:

<script>
$("#add").click(function(){
var btn='<input type="button" class="button" value="del" >';
$("#box").html(btn);
});
$(".button").click(function(){
alert(1);
});

</script>

 

 
 

 

但在我们动态创建了.button之后,新创建的.button元素并没有点击效果但原来写的.button有点击弹窗事件,这就是问题所在。

 

 

解决办法

我们来解决这个问题,这个问题的关键原因在于:动态生成的元素要通过事件委托来处理。

我们通过事件委托来解决问题:

$("#box").on('click','.button',function(){
alert(1);
});

希望我的答案能解决你遇到的问题。

转载于:https://www.cnblogs.com/zishan/p/8182886.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值