随笔 - 394  文章 - 0  评论 - 946  阅读 - 143万 

本文主要介绍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
posted on   程序诗人  阅读(985)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示