【转载】jquery 自定义事件

以下故事纯属虚构,如有雷同为巧合...

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

知识要点:

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

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

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

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

//这个是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"});