最近工作项目中出现了这个问题,在不刷新页面的时候再点击click事件既然累加执行了。网上找了很多方案都没解决,最后无奈只能每次执行之后都刷新页面,但是这样的体验是非常差的。今天有空闲来就再找解决方案,最后终于有个好的解决方法了。
之前有网友有提过用$("#box").one("click",function(){ }),但是对于我那个项目好像不行,
最后用了
$("#box").unbind("click").bind("click",function(){
})
完美解决了
那么为什么会累加执行呢?看到的一些答案是:
在页面中为一个元素绑定事件,事件执行后页面未刷新且元素还在,然后你再次点击,元素又被绑定个一次点击事件,这样第二次点击就会执行两次,以此类推。
上面的解决方案的原因是:
在每次绑定点击事件前先解除之前的事件绑定,再为元素绑定事件,类似于先清空
大概就是这样子了