先简单说下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> </div> <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> |
时间: 2024-09-14 13:55:15