昨天项目中遇到一个问题:
场景:打开弹窗页面,点击按钮动态对表格添加一行,关闭弹窗之后再打开弹窗,点击按钮就出现了直接添加两行,再关闭再打开弹窗,点击按钮直接添加了四行
问题分析:网上查了一次点击事件多次执行,发现是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(){........
|