添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
相关文章推荐
豪爽的豌豆  ·  [Solved] mysql left ...·  10 月前    · 
爱吹牛的枇杷  ·  POCO C++ - NET SSL - ...·  1 年前    · 


绑点击事件这个是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>