jQuery的绑定事件非常方便,有bind、live、one还有它帮你把一些常用的事件给单独了出来,比如控件的onclick事件,我们绑定onclick事件的时候只需要
- $("#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#的事件如出一辙,事件的绑定是叠加(+=)而不是覆盖。
- var Eat = function() {
-
alert("我要吃饭"); -
} -
-
var PayMoney = function() { -
alert("先付钱"); -
} -
-
jQuery(document).ready(function() { -
$("#testButton").click(Eat); -
$("#testButton").bind("click", PayMoney); -
});
通过上面的例子,我们发现会先弹出:“我要吃饭”紧接着会弹出“先付钱”,说明它的绑定是通过onclick+=fn进行的。我们修改下ready的方法:
- jQuery(document).ready(function() {
-
$("#testButton").click(Eat); -
$("#testButton").unbind(); -
$("#testButton").bind("click", PayMoney); -
});
又出错了,呵呵,这次点击按钮的话,只会执行PayMoney,不会执行Eat,那如果把unbind()放在bind后面的话,这样这个按钮就不会起作用了。但如果我要去掉绑定的PayMoney方法呢?这时候我们应该这样写:
- jQuery(document).ready(function() {
-
$("#testButton").click(Eat); -
$("#testButton").bind("click", PayMoney); -
$("#testButton").unbind("click", PayMoney); -
});
嘿嘿,跟bind其实一个样,不过接下来你将看到一个bug(我不知道算不算),让我们近距离体验一下
- :<input id="testButton" type="button" value="Test Button" οnclick="Eat();" />
- <script type="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事件。
- :<head>
-
-
<script type="text/javascript" src="jquery-1.2.6.min.js"></script> -
-
<script type="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>
-
<input id="JeffreyPay" οnclick="PayMoney('赵帅');" type="button" value="老赵付钱" /> -
<input id="JamesPay" type="button" οnclick="PayMoney('老应');" value="老应付钱" /> -
<input id="DlyingPay" type="button" οnclick="PayMoney('陈大');" value="老陈付钱" /> - </body>