博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
javascript之Publish/Subscribe模式
阅读量:4940 次
发布时间:2019-06-11

本文共 1355 字,大约阅读时间需要 4 分钟。

  发布/订阅,是一种由两个部分构成:发布者和订阅者的消息传递模式。发布者将消息发布到特定频道,而订阅者接听频道,当频道上有消息发布时将接收到通知。

1、用javascript实现Pub/Sub模式代码:

1 var PubSub = { 2            //订阅 3            subscribe : function(ev,callback){ 4                 this._callback || (this._callback = {}); 5                 (this._callback[ev] || (this._callback[ev] = [])).push(callback); 6                 return this; 7             }, 8             //取消订阅 9             unsubscribe : function(ev){10                 if(!this._callback || !this._callback[ev]){11                     return this;12                 }13                 this._callback[ev] = null;14                 delete this._callback[ev];15                 return this;16             },17              //发布18             publish : function(){19                 var callback, list, i, length, args = [].slice.call(arguments,0), ev = args.shift();20                 if(!(callback = this._callback) || !(list = this._callback[ev])){21                     return this;22                 }23                 for(i = 0, length = list.length; i < length; i++){24                       list[i].apply(this, args);25                 }26                 return this;27             }28     };29     PubSub.subscribe('wen',function(){alert('Wen!!!');}).publish('wen').unsubscribe('wen').publish('wen');
View Code

 

 

 

转载于:https://www.cnblogs.com/bender/p/3360402.html

你可能感兴趣的文章
结构与联合
查看>>
关于JS历史
查看>>
软件架构师工作流程
查看>>
将txt文本转换为excel格式
查看>>
BUPT复试专题—众数(2014)
查看>>
css-sprite切割图片(加快网页加载速度)
查看>>
20145316 《信息安全系统设计基础》第十四周学习总结
查看>>
Liferay7 BPM门户开发之18: 理解ServiceContext
查看>>
从零开始学区块链(3)
查看>>
Intel Galileo development documentation
查看>>
Jquery特效
查看>>
web服务器
查看>>
EV: Workaround to Allow Only One Instance or Window of outlook
查看>>
数据校验,
查看>>
IntelliJ IDEA完美解决tomcat8+乱码问题
查看>>
GDI+ ColorMatrix的完全揭秘
查看>>
破解电信光猫华为HG8120C关闭路由功能方法
查看>>
在Qt示例项目的C ++ / QML源中的//! [0]的含义是什么?
查看>>
【智能家居篇】wifi网络接入原理(上)——扫描Scanning
查看>>
操作引入xml文件的书包(定位到指定节点)
查看>>