微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

jQuery绑定自定义事件的魔法升级版

jQuery绑定自定义事件

首先让我们来看看jQuery绑定自定义事件的使用方法,你可以使用bind或者live来订阅一个事件(当然1.7以后也可以使用on了),代码如下:

rush:js;"> $("#myElement").bind('customEventName',function(e){ ... }); $(".elementsClass").live('customEventName',function(e){ ... });

然后通过如下方式来触发事件:

rush:js;"> $("#myelement").trigger('customEventName');

或者你也可以为自定义事件增加额外的参数,样例如下:

rush:js;"> $("#myelement").bind('customEventName',function(e,data){ if(data.custom) ... }); $("#myelement").trigger('customEventName',{ custom: false });

魔法升级

所谓魔法升级,其实是想让整个程序所有的自定义事件能够自动注册并绑定jQuery上,然后执行的时候,所有注册该事件的模块都会执行。比如模块User.js里定义的UserUpdate方法和Blogs.js里定义的BlogUpdate方法都定义了在发布一篇博客的时候需要执行的function函数,整个时候我们可以通过注册统一的事件名称(例如BlogAdded)bind到jQuery指定的一个容器上(例如document)上,然后发布博客成功以后,执行$(document).trigger("BlodAdded")就OK了。

下面我们给个通用的样例代码

rush:js;"> var components = [User,Blog,Group,Friend,Topic,Photo]; var eventTypes = ["AddComplete","UpdateComplete","DeleteComplete","LockComplete","UnLockComplete"]; $.each(components,function(i,component) { $.each(eventTypes,eventType) { var handler = component[eventType]; if (handler) $(document).bind(eventType,handler); }); })

然后每个js模块定义的代码安装如下格式:

rush:js;"> User= { AddComplete: function(e,data) { //... },UpdateComplete: function(e,data) { //... } }

这样,不管在任何地方,如果我们需要的话,就可以使用jQuery的方式来触发我们的事件了:

rush:js;"> $(document).trigger("UpdateComplete",data);

通过这种方法,大家可以发现一个模块的method只能注册一个事件,那如果我们通过一个方法注册多个事件触发的话,可以使用如下方式:

rush:js;"> var blogController = { blogAddOrUpdateComplete: function() { //... } } blogController.blogAddComplete = blogController.blogUpdateComplete = blogController.blogAddOrUpdateComplete;

最后注意:本文只是展示一个简单的例子,不要混用不同module同一事件名称用法哦,比如,User.js里的AddComplete和Blog.js里的AddComplete可能根本就没有关系,也就是说只处理自己相应的逻辑,这时候,就不应该统一处理这个事件,但如果要检测的东西是一样的话,就可以使用,比如disableuserComplete,就可以通用,因为User模块需要处理禁用账户以后的操作,Blog模块可能也需要处理禁用账户以后的操作。

以上就是本文的全部内容,了解更多jQuery的语法,大家可以查看:《》,也希望大家多多支持编程之家。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


jQuery表单验证提交:前台验证一(图文+视频)
jQuery表单验证提交:前台验证二(图文+视频)
jQuery如何实时监听获取input输入框的值
JQuery怎么判断元素是否存在
jQuery如何实现定时重定向
jquery如何获取复选框选中的值
jQuery如何清空form表单数据
jQuery怎么删除元素节点
JQuery怎么循环输出数组元素
jquery怎么实现点击刷新当前页面