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