JS事件click调用两次、多次

2 篇文章 0 订阅

昨天项目中遇到一个问题:

场景:打开弹窗页面,点击按钮动态对表格添加一行,关闭弹窗之后再打开弹窗,点击按钮就出现了直接添加两行,再关闭再打开弹窗,点击按钮直接添加了四行

问题分析:网上查了一次点击事件多次执行,发现是click事件多次绑定,我绑定事件是在弹窗加载的时候,绑定按钮添加事件,每次弹窗就会加载一次,再次弹窗会加载两次,再再次弹窗会加载四次,click事件绑定并不会覆盖原先的事件,而是累加,且方法里面的值也会记录为原先绑定时候的值,例如这段代码:点击切换,再点击ss,这时候弹1,如果再次点击切换,这时候就会弹窗2,再弹窗1,再次点击切换会再依次弹出321

<html>
<head>
<script type="text/javascript" src="/jquery/jquery.js"></script>
<script type="text/javascript">
$(document).ready(function(){
  $("#b").click(function(){
      var s = 1;
   $("#a").click(function(){
    alert(s);
    s++;
   });
  });
});
</script>
</head>
<body>
<p>这是一个段落。</p>
<button id="a">ss</button>
<button id="b">切换</button>
</body>
</html>

解决方案:在绑定事件之前先关掉原先的事件即可

   $("#a").unbind("click");或者$("#a").off("click");(第二张有些可能不支持)
 $("#a").click(function(){........

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值