JQuery最佳实践:JQuery自定义事件的应用

本文通过一个生动的例子介绍了如何在JQuery中实现自定义事件,包括事件的绑定、触发和解除绑定等操作,并展示了如何利用带命名空间的事件处理函数避免事件冲突。

本文主要介绍JQuery框架里面支持的自定义事件模型,通过实例说明什么时候可以利用事件模型进行面向对象的JS编程,以及利用“带命名空间的事件处理函数”来避免unbind时影响别的事件订阅。

知识要点:

1,自定义事件custom events及事件的订阅

2,trigger、bind、unbind方法的使用

3,带命名空间的自定义事件

将下面内容粘贴至txt文档后再直接粘贴至firebug的控制台,运行看看。

/*
JQuery自定义事件的应用-Javascript OO
有一帅哥叫Levin,在某公司前端设计部工作,他的主管是大帅哥A,经理是大美眉B。
领导们希望可以抽空瞄瞄这家伙每周的工作情况,于是。。。
Levin每周一要用google doc写一份关于上周工作的总结,并被要求写完后要MSN通知A和B。。。
Levin非常乐意做周总结,但是他提出了一个建议:
既然我用google doc写好了,你们喜欢看便用google reader订阅我的文档更新吧,我不喜欢用微软的MSN。。。

这丫...A和B头顶乌鸦飘了几秒,但欣然答应。
*/

 

//这个是Levin同学
 


   
var Levin = {name: " Levin " };
Levin
= $(Levin);


//每周要写周总结


   
Levin.bind( " evt_weeklyReport " , function (evt){
alert(
this .name + " 高呼:Yeah!周总结已经写好啦. " );
});

//主管A

   
var A = {name: " 帅哥A " };

//他要订阅Levin的周总结

 


   
A.rssLevin = function (){
Levin.bind(
" evt_weeklyReport.fromA " , function (evt,data){
alert(A.name
+ " :嗯,不错,Levin还是挺积极的嘛! " );
})
};
A.rssLevin();

//经理B

 


   
var B = {name: " 美眉B " };

 
//她也订阅Levin的周总结


   
B.rssLevin = function (){
Levin.bind(
" evt_weeklyReport.fromB " , function (evt,data){
alert(B.name
+ " :周总结呆会看,先看看他说的那个网站 " );
window.location
= evt.site;
})
};
B.rssLevin();

 

 

//每次Levin同学写好周总结后便会用google doc发布一下
 


   
Levin.trigger({type: " evt_weeklyReport " ,site: " http://vivasky.com " });

 

//经理B突然有一天去搜狐做了,不再订阅Levin的周结...
 


   
B.unRssLevin = function (){
alert(
" 我要去搜狐做副总裁啦,哈哈 " );
Levin.unbind(
" evt_weeklyReport.fromB " );
return true ;
}();
 

//尽管B跳槽了,周总结还是要按时发布的。。。

   
Levin.trigger({type: " evt_weeklyReport " ,site: " http://vivasky.com " });

 

---------华丽的分隔线---------- 
 

活得出色点

Levin

http://vivasky.com

作者:Mamboer

转载于:https://www.cnblogs.com/scy251147/archive/2010/09/13/1824729.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值