最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
jQuery绑定和解绑点击事件及重复绑定解决办法
时间:2022-11-14 22:03:28 编辑:袖梨 来源:一聚教程网
先简单说下jQuery绑定和解绑点击事件的方法,直接上代码:
| 代码如下 | 复制代码 |
|
|
|
即,要对一个绑定过点击事件的元素绑定其它函数,需先对其解绑。
上面的代码看起来好简单,但是实际应用中却要复杂的多。举一个项目中的实例吧。
两个显示标签云的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")方法先解除绑定的事件再绑定新事件,即在给对象绑定事件之前先移除该对象上的原有事件
完整测试代码:
| 代码如下 | 复制代码 |
|
(点击此按钮两次及以上,即可触发重复绑定,再点击下面的按钮就可看到结果) |
|
相关文章
- 空灵诗篇在哪预约 空灵诗篇官网预约入口 12-16
- 粒粒的小人国什么时候开服 粒粒的小人国开服时间 12-16
- 三角洲新赛季更新时间 三角洲行动新赛季时长介绍 12-16
- 保卫向日葵怎么获得奥术 奥术获取途径全面汇总 12-16
- 保卫向日葵怎么快速消耗体力 体力快速消耗实用方法介绍 12-16
- 保卫向日葵怎么开启圣物栏 圣物栏解锁方法与扩容技巧 12-16