分解jQuery对相关控件的事件操作
创始人
2024-04-17 11:10:48
0

今天突然对他的事件产生了兴趣,先前也碰到过,也没整理,今天有空就弄一下咯。

对于控件的事件,jQuery已经提供了丰富的方法,包括绑定、一次绑定、触发等,阿拉今早看看叫一哪能用额伐,大虾路古就可以了。

jQuery的绑定事件非常方便,有bind、live、one还有它帮你把一些常用的事件给单独了出来,比如控件的onclick事件,我们绑定onclick事件的时候只需要

  1. $("#testButton").click(function() {  
  2.     alert("I'm Test Button");  
  3. }); 

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

  1. var Eat = function() {  
  2.         alert("我要吃饭");  
  3.     }  
  4.  
  5.     var PayMoney = function() {  
  6.         alert("先付钱");  
  7.     }  
  8.  
  9.     jQuery(document).ready(function() {  
  10.         $("#testButton").click(Eat);  
  11.         $("#testButton").bind("click", PayMoney);  
  12.     }); 

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

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

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

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

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

  1.  id="testButton" type="button" value="Test Button" onclick="Eat();" /> 
  2.  type="text/javascript"> 
  3.         jQuery(document).ready(function() {  
  4.             $("#testButton").unbind("click", Eat);  
  5.             $("#testButton").unbind();  
  6.             $("#testButton").bind("click", PayMoney);  
  7.         });  
  8.  

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

  1.  
  2.  
  3.      type="text/javascript" src="jquery-1.2.6.min.js"> 
  4.  
  5.      type="text/javascript"> 
  6.  
  7.         var PayMoney = function(name) {  
  8.             alert(name + ":今天我请客,我来付钱");  
  9.         }  
  10.  
  11.         jQuery(document).ready(function() {  
  12.             $("#JeffreyPay").attr("onclick", "");  
  13.             $("#JamesPay").attr("onclick", "");  
  14.  
  15.             $("#JeffreyPay").click(function() {  
  16.                 alert("。。。。这里不能刷卡");  
  17.             });  
  18.  
  19.             $("#JeffreyPay").click(function() {  
  20.                 PayMoney("陈大");  
  21.             });  
  22.             $("#JamesPay").bind("click", function() {  
  23.                 alert("。。。。忘记带钱包了");  
  24.             });  
  25.             $("#JamesPay").bind("click", $("#DlyingPay").attr("onclick"));  
  26.         });  
  27.      
  28.  
  29.  
  30.  
  31.      id="JeffreyPay" onclick="PayMoney('赵帅');" type="button" value="老赵付钱" /> 
  32.      id="JamesPay" type="button" onclick="PayMoney('老应');" value="老应付钱" /> 
  33.      id="DlyingPay" type="button" onclick="PayMoney('陈大');" value="老陈付钱" /> 
  34.  

以上内容均为原创,不要用在邪恶的地方哦。其实在绑定事件上还存在很多bug,大家可以稍微修改下上面的效果就会知道了,比如自动执行,绑定失败等,呵呵。

【编辑推荐】

  1. jQuery调用WCF服务传递JSON对象
  2. 学习jQuery必须知道的几种常用方法
  3. 用XML+XSLT+CSS+JQuery组建ASP.NET网站
  4. 使用jQuery和PHP构建一个受Ajax驱动的Web页面
  5. jQuery调用WCF需要注意的一些问题

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...