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

时间:2021-05-26

知识要点:

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://jb51.net"});


//经理B突然有一天去搜狐做了,不再订阅Levin的周结...
[code]
B.unRssLevin=function(){
alert("我要去搜狐做副总裁啦,哈哈");
Levin.unbind("evt_weeklyReport.fromB");
return true;
}();
[html]

//尽管B跳槽了,周总结还是要按时发布的。。。
复制代码 代码如下:
Levin.trigger({type:"evt_weeklyReport",site:"http://jb51.net"});

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章