首页  ·  知识 ·  前端
jQuery的绑定事件
网友    综合  编辑:dezai   图片来源:网络
jQuery的绑定事件非常方便,有bind、live、one还有它帮你把一些常用的事件给单独了出来,比如控件的onclick事件,我们绑定onclick事件
 jQuery的绑定事件非常方便,有bind、live、one还有它帮你把一些常用的事件给单独了出来,比如控件的onclick事件,我们绑定onclick事件的时候只需要
  1. $("#testButton").click(function() { 
    • alert("I'm Test Button"); 
      • }); 

就这样我们在testButton这个按钮上绑定了onclick事件,执行alert语句。我们也可以使用$("#testButton").click();来触发这个onclick事件,一切都非常ok啦。以上有点sb了,接下来看看取消事件。jQuery有unbind的方法,专门来取消绑定的,也就是取消事件,按照上面的例子的话,应该使用:$("#testButton").unbind("click");恩,看上去非常好,如果你的click有2个事件的话,你还可以使用unbind("click",  fnName)来删除特定函数的绑定。为什么有这个取消特定函数的方法呢,我们来看下例子,我们会发现,javascript的事件,跟C#的事件如出一辙,事件的绑定是叠加(+=)而不是覆盖。 

  1. var Eat = function() { 
    • alert("我要吃饭"); 
          • var PayMoney = function() { 
            • alert("先付钱"); 
                  • jQuery(document).ready(function() { 
                    • $("#testButton").click(Eat); 
                      • $("#testButton").bind("click",  PayMoney); 
                        • }); 

通过上面的例子,我们发现会先弹出:“我要吃饭”紧接着会弹出“先付钱”,说明它的绑定是通过onclick+=fn进行的。我们修改下ready的方法: 

  1. jQuery(document).ready(function() { 
    • $("#testButton").click(Eat); 
      • $("#testButton").unbind(); 
        • $("#testButton").bind("click", PayMoney); 
          • }); 

又出错了,呵呵,这次点击按钮的话,只会执行PayMoney,不会执行Eat,那如果把unbind()放在bind后面的话,这样这个按钮就不会起作用了。但如果我要去掉绑定的PayMoney方法呢?这时候我们应该这样写: 

  1. jQuery(document).ready(function() { 
    • $("#testButton").click(Eat); 
      • $("#testButton").bind("click", PayMoney); 
        • $("#testButton").unbind("click", PayMoney); 
          • }); 

嘿嘿,跟bind其实一个样,不过接下来你将看到一个bug(我不知道算不算),让我们近距离体验一下

  1. <inputid="testButton" type="button" value="Test  Button" onclick="Eat();" />
    • <scripttype="text/javascript">
      • jQuery(document).ready(function()  { 
        • $("#testButton").unbind("click", Eat); 
          • $("#testButton").unbind(); 
            • $("#testButton").bind("click", PayMoney); 
              • }); 
                • </script>

大家猜猜,会显示什么?吃饭?付钱?答案是Eat ->  PayMoney,啊!!!我这里取消了绑定,又删除了特定的绑定,为什么还会执行Eat呢?其中的原由要看jQuery的类库了,我估计它只删除了通过JQuery绑定的那些事件了,呵呵。那这时候我们该如何呢?好在jQuery有很多方法,其中一个就是attr,他是对Dom元素的属性进行操作,我们利用attr来消除input上的click事件。 $("#testButton").attr("onclick", "");这样就可以把onclick事件清除了,记住,attr上因为是元素的属性,所以这里要写  “onclick”  而不是click,因为click是jQuery封装好的简写方式。好了,绑定就到这里了,弄个场景,大家也好记得住点:一日,老应、老赵、老陈出去吃饭,吃饱了,喝足了,准备付钱了,这时候

  1. <head>
      • <scripttype="text/javascript"  src="jquery-1.2.6.min.js"></script>
          • <scripttype="text/javascript">
              • var PayMoney = function(name)  { 
                • alert(name + ":今天我请客,我来付钱"); 
                      • jQuery(document).ready(function()  { 
                        • $("#JeffreyPay").attr("onclick", ""); 
                          • $("#JamesPay").attr("onclick", ""); 
                              • $("#JeffreyPay").click(function() { 
                                • alert("。。。。这里不能刷卡"); 
                                  • }); 
                                      • $("#JeffreyPay").click(function() { 
                                        • PayMoney("陈大"); 
                                          • }); 
                                            • $("#JamesPay").bind("click", function() { 
                                              • alert("。。。。忘记带钱包了"); 
                                                • }); 
                                                  • $("#JamesPay").bind("click", $("#DlyingPay").attr("onclick")); 
                                                    • }); 
                                                      • </script>
                                                          • </head>
                                                            • <body>
                                                              • <inputid="JeffreyPay"  onclick="PayMoney('赵帅');" type="button" value="老赵付钱"  />
                                                                • <inputid="JamesPay" type="button"  onclick="PayMoney('老应');" value="老应付钱" />
                                                                  • <inputid="DlyingPay" type="button"  onclick="PayMoney('陈大');" value="老陈付钱" />
                                                                    • </body
本文作者:网友 来源:网络
CIO之家 www.ciozj.com 微信公众号:imciow
   
免责声明:本站转载此文章旨在分享信息,不代表对其内容的完全认同。文章来源已尽可能注明,若涉及版权问题,请及时与我们联系,我们将积极配合处理。同时,我们无法对文章内容的真实性、准确性及完整性进行完全保证,对于因文章内容而产生的任何后果,本账号不承担法律责任。转载仅出于传播目的,读者应自行对内容进行核实与判断。请谨慎参考文章信息,一切责任由读者自行承担。
延伸阅读