jQuery相关控件的事件操作分解
2023-06-13 09:14:11 时间
今天突然对他的事件产生了兴趣,先前也碰到过,也没整理,今天有空就弄一下咯。
对于控件的事件,jQuery已经提供了丰富的方法,包括绑定、一次绑定、触发等,阿拉今早看看叫一哪能用额伐,大虾路古就可以了。
jQuery的绑定事件非常方便,有bind、live、one还有它帮你把一些常用的事件给单独了出来,比如控件的onclick事件,我们绑定onclick事件的时候只需要
复制代码代码如下:
对于控件的事件,jQuery已经提供了丰富的方法,包括绑定、一次绑定、触发等,阿拉今早看看叫一哪能用额伐,大虾路古就可以了。
jQuery的绑定事件非常方便,有bind、live、one还有它帮你把一些常用的事件给单独了出来,比如控件的onclick事件,我们绑定onclick事件的时候只需要
$("#testButton").click(function(){
alert("I"mTestButton");
});
就这样我们在testButton这个按钮上绑定了onclick事件,执行alert语句。我们也可以使用$("#testButton").click();来触发这个onclick事件,一切都非常ok啦。以上有点sb了,接下来看看取消事件。jQuery有unbind的方法,专门来取消绑定的,也就是取消事件,按照上面的例子的话,应该使用:$("#testButton").unbind("click");恩,看上去非常好,如果你的click有2个事件的话,你还可以使用unbind("click",fnName)来删除特定函数的绑定。为什么有这个取消特定函数的方法呢,我们来看下例子,我们会发现,javascript的事件,跟C#的事件如出一辙,事件的绑定是叠加(+=)而不是覆盖。
varEat=function(){
alert("我要吃饭");
}
varPayMoney=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" onclick="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事件。$("#testButton").attr("onclick","");这样就可以把onclick事件清除了,记住,attr上因为是元素的属性,所以这里要写“onclick”而不是click,因为click是jQuery封装好的简写方式。好了,绑定就到这里了,弄个场景,大家也好记得住点:一日,老应、老赵、老陈出去吃饭,吃饱了,喝足了,准备付钱了,这时候
:<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" onclick="PayMoney("赵帅");" type="button" value="老赵付钱" />
<input id="JamesPay" type="button" onclick="PayMoney("老应");" value="老应付钱" />
<input id="DlyingPay" type="button" onclick="PayMoney("陈大");" value="老陈付钱" />
</body>
以上内容均为原创,不要用在邪恶的地方哦。其实在绑定事件上还存在很多bug,大家可以稍微修改下上面的效果就会知道了,比如自动执行,绑定失败等,呵呵。
相关文章
- 生成二维码的 jQuery 插件:jquery.qrcode.js
- jQuery实现返回顶部功能详解编程语言
- jquery关于移动端的点击事件解析详解编程语言
- jquery换一批的写法详解编程语言
- javascript基于jQuery的表格悬停变色/恢复,表格点击变色/恢复,点击行选Checkbox
- javascript的onchange事件与jQuery的change()方法比较
- JQuery下的Live方法和$.browser方法使用代码
- fancybox1.3.1基于Jquery的插件在IE中图片显示问题
- 基于jquery的动态创建表格的插件
- jQuery代码优化之基本事件
- jquery中dom操作和事件的实例学习-表单验证
- jQuery事件绑定.on()简要概述及应用
- jQuery用unbind方法去掉hover事件及其他方法介绍
- Jquery实现列表(隔行换色,全选,鼠标滑过当前行)效果实例
- js/jquery去掉空格,回车,换行示例代码
- 基于jquery插件制作左右按钮与标题文字图片切换效果
- JQuery验证jsp页面属性是否为空(实例代码)
- jquery获取元素值的方法(常见的表单元素)
- JQuery中阻止事件冒泡几种方式及其区别介绍
- jQuery回车事件enter使用示例
- jquery防止重复执行动画避免页面混乱
- jQuery中多个元素的Hover事件解决方案
- jquery操作对象数组元素方法详解