一聚教程网:一个值得你收藏的教程网站

热门教程

jQuery绑定和解绑点击事件及重复绑定解决办法

时间:2022-11-14 22:03:28 编辑:袖梨 来源:一聚教程网

先简单说下jQuery绑定和解绑点击事件的方法,直接上代码:

代码如下 复制代码


$("#element").click(function(){}); //绑定点击事件函数
$("#element").unbind(); //解绑点击事件
$("#element").click(function(){}); //绑定其它函数

即,要对一个绑定过点击事件的元素绑定其它函数,需先对其解绑。

上面的代码看起来好简单,但是实际应用中却要复杂的多。举一个项目中的实例吧。

两个显示标签云的DIV,DIV1显示选中的标签,DIV2显示可选的标签。DIV2中的任一个标签被点中后会从DIV2中消失并添加到DIV1中,再在DIV1点击它时,它又会回到DIV2。两个DIV中的标签总数、单个标签的内容保持不变。这个效果我花了差不多一个半小时才搞定,就是因为对jQuery绑定和解绑点击事件理解的不到位。

我最开始的理解是:当一个标签从DIV1中移除并添加到DIV2中时,其原来绑定的所有事件都会消失,我可以从DIV2中析取这个标签并给它绑定新的点击事件。结果是:再点击它时它并没有回到DIV1,而是还是在DIV2中,只是位置被移到了最后。我误以为这个标签还属于DIV1,殊不知不是DIV的归属问题,而是点击事件的绑定问题。

总结还是那句话:要对一个绑定过点击事件的元素绑定其它函数,需先对其解绑。

一$.fn.live 重复绑定

解决:使用die()方法,在live()方法绑定前,将此元素上的前面被绑定的事件统统解除,然后再通过live()方法绑定新的事件。

//先通过die()方法解除,再通过live()绑定$(“#selectAll”).die().live(“click”,function(){//事件运行代码});

二click等事件

解决:使用unbind("click")方法先解除绑定的事件再绑定新事件,即在给对象绑定事件之前先移除该对象上的原有事件


完整测试代码:

代码如下 复制代码


(点击此按钮两次及以上,即可触发重复绑定,再点击下面的按钮就可看到结果)









热门栏目