绑点击事件这个是jquery一个常用的功能,如click,unbind等等这些事件绑定事情,但还有很多朋友不知道,下面我来给大家介绍jQuery绑定和解绑点击事件及重复绑定解决办法,有需要了解的同学可参考。
先简单说下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")方法先解除绑定的事件再绑定新事件,即在给对象绑定事件之前先移除该对象上的原有事件
完整测试代码:
代码如下
|
复制代码
|
<div class="box">
<button id="test">重复绑定触发按钮</button>(点击此按钮两次及以上,即可触发重复绑定,再点击下面的按钮就可看到结果)
<br/><br/>
<button id="test1">click重复绑定测试按钮</button>
<button id="test2">click绑定一次测试按钮</button>
<button id="test3">live重复绑定测试按钮</button>
<button id="test4">live绑定一次测试按钮</button>
<script type="text/javascript" src="../static/jquery-1.6.1.min.js"></script>
<script type="text/javascript">
$(function(){
var i = 1,j=1,k=1,h=1,n=1;
var triggerBind = function(){
$("#test1").click(function() {
alert("click未解除绑定重复绑定执行第" + j++ + "次");
$("#test2").unbind('click').click(function() {
alert("click解除绑定执行" + k++ + "次");
$("#test3").live("click",function() {
alert("live未解除绑定重复执行第" + h++ + "次");
$("#test4").die().live("click",function() {
alert("live解除绑定后执行" + n++ + "次");
$("#test").click(function() {
triggerBind();
alert("触发绑定点击第" + i++ + "次");
</script>
|