JQuery 对控件的事件操作

JQuery是非常棒的js类库,有丰富的UI库和插件,不过我钟爱他的是他的选择器,感觉其他功能有时跟后台人员距离很远,所以一般我也只使用一下他的选择器。

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

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

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);});
又SB了,呵呵,这次点击按钮的话,只会执行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>

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

http:/inday.cnblogs.com

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/406796.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

搭建VS2008+OpenCV2.1开发环境

引子&#xff1a;如题&#xff08;非原创&#xff0c;非转载&#xff0c;非翻译&#xff09;。其实本菜鸟很纠结于CSDN博客文章的分类&#xff1a;原创&#xff1b;转载&#xff1b;翻译。菜鸟以博客备忘&#xff0c;首先Google&#xff0c;然后试&#xff0c;最后写博客&#…

repalce

1、replace基本用法 <script>/*要求将字符串中所有的a全部用A代替*/var str "javascript is great script language!";//只会将第一个匹配到的a替换成Aconsole.log(str.replace("a", "A")); // > jAvascript is great script language…

Win8环境下 IIS6部署MVC网站出现的无法显示此网页错误

在Win7环境下做好的网站&#xff0c;新的Win8环境发布出现如下图错误&#xff1a; 解决方法如下&#xff1a; 运行&#xff1a; 转载于:https://www.cnblogs.com/xiashenbin/p/4098274.html

软件质量管理之痛

相信不少软件开发公司都存在质量管理部门。而且&#xff0c;如果一个公司稍微正规的话,一定会使用一个缺陷跟踪软件系统&#xff0c;比如开源的Bugzilla&#xff0c;或是IBM的ClearQuest等等。那质量管理部门是如何跟踪和控制软件质量的呢&#xff1f;毫无疑问&#xff0c;需要…

COM、COM+和DCOM的定义和区别

From:http://zouyou1986.blog.163.com/blog/static/1772625920105461931335/ 解释COM、COM和DCOM的定义和区别&#xff1f; COM是组件对象模型,是实现3/N层应用的基础,它的目的就是组件化,应用程序分层.DCOM是分布式的COM,也就说可以远程的创建,最初它利用远程自动化来实现,用…

OpenCV:SURF算法浅析

引子&#xff1a; 课题需要SURF特征提取算法&#xff0c;在运动中提取摄像头图像中的特征点&#xff0c;并进行跟踪匹配&#xff0c;以此估计运动状态。开始找到了SIFT算法&#xff0c;SIFT特征提取具有极强的适应能力&#xff0c;但运算量稍大&#xff0c;后来就有了SURF特征提…

Codeforces Round #277(Div 2) A、B、C、D、E题解

转载请注明出处&#xff1a; http://www.cnblogs.com/fraud/ ——by fraud A. Calculating Function 水题&#xff0c;判个奇偶即可 1 #include <iostream>2 #include <sstream>3 #include <ios>4 #include <iomanip>5 #include <functio…

Vue 中使用watch监听$route 无效问题

Vue 中使用watch监听$route失效问题&#xff01; 今天在项目操作中发现一个问题&#xff0c;在watch里面监听$route变化&#xff0c;发现并没有监听到&#xff0c;查阅了一些资料最终解决&#xff0c;现写出与大家共同分享&#xff0c;也忘出现此问题的同学也能顺利解决 路由词…

oa 系统后期安装服务

http://www.didibabawu.com/oa.htm

.idl与.odl的区别

From: http://hi.baidu.com/%CD%E6%CA%AF%CD%B7%B5%C4%D0%A1%BA%A2/blog/item/1b9a942fe8cfcf594ec22629.html 1. .odl和.idl在com中的功能相同. 前者是ActiveX中的 后者是ATL中. 可在前者的文件中 用 #import "XXXXX.idl" 的方式包含后者. 反过来没有试过. 2. …

Mac OS X 安装和配置ngrok

一、下载ngrok 到官网下载ngrok: https://ngrok.com/download 二、配置ngrok 进入终端&#xff0c;执行以下命令&#xff1a; open -e .bash_profile 修改.bash_profile&#xff08;以实际安装目录为准&#xff09;&#xff1a; export PATH${PATH}:/Users/xuxiansheng/D…

Windows Phone理解和运用ItemTemplate、ContentTemplate和DataTemplate

2.2.5 ItemTemplate、ContentTemplate和DataTemplate 在理解ItemTemplate、ContentTemplate和DataTemplate的关系的之前&#xff0c;我们先来看看ContentControl类和ItemsControl类。ContentControl类是内容控件的基类&#xff0c;如Button, CheckBox&#xff0c;最明显的特征就…

杂七杂八的杂记

引子&#xff1a;这里是零零星星的没有系统总结的东西&#xff0c;或者是有待继续了解之前一些零散的备忘。 高手达人慎入&#xff0c;以免贻笑大方&#xff0c;如果误入进来&#xff0c;敬请指导一二。 1、今天发现一个Vc 中一个很好的东西&#xff1a;vector。需要#include…

C#和C++结构体Socket通信

From: http://hi.baidu.com/yangliangwang/blog/item/1a0116138ff098d6f6039ea9.html 最近在用C#做一个项目的时候&#xff0c;Socket发送消息的时候遇到了服务端需要接收C结构体的二进制数据流&#xff0c;这个时候就需要用C#仿照C的结构体做出一个结构来&#xff0c;然后将其…

用 vue-route 的 beforeEach 实现导航守卫(路由跳转前验证登录)

路由跳转前做一些验证&#xff0c;比如登录验证&#xff08;未登录去登录页&#xff09;&#xff0c;是网站中的普遍需求。对此&#xff0c;vue-route 提供的 beforeRouteUpdate 可以方便地实现导航守卫&#xff08;navigation-guards&#xff09;。 导航守卫&#xff08;navig…

统计代码行数

使用终端&#xff0c;cd到项目下 find . "(" -name "*.m" -or -name "*.mm" -or -name "*.cpp" -or -name "*.h" -or -name "*.rss" ")" -print | xargs wc -l 转载于:https://www.cnblogs.com/mo-shou…