发布者订阅者模式
2018-07-24 08:23:54来源:博客园 阅读 ()
看了网上的资料感觉有两种实现,一种是发布的时候有关键字key,然后就执行所有订阅了key的事件,还有一种是没有key直接绑定在发布对象上,对象调用public方法然后执行所有绑定的函数
说到底区别就是前者是多个不同键值的数组存事件,后者是只有一个数组存所有时间,下面的代码是属于前一种
class EventEmitter{ constructor(){ this.EventList = {} } subscribe(key,fun){ if(!this.EventList.hasOwnProperty(key)){ this.EventList[key] = [] } this.EventList[key].push(fun) } unsubscribe(key,fun){ if(!this.EventList[key]) return this.EventList = this.EventList[key].filter((f)=>{ if(f!=fun) return f }) } public(key,arg){ if(!this.EventList[key]){ console.log('no respond event') return } this.EventList[key].forEach(fun=>{ fun(arg) }) } } var EE = new EventEmitter() var print = (data)=>{ console.log(data) } EE.subscribe('done',print) EE.public('done','12223') EE.unsubscribe('done',print) EE.public('done','12223')
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- javascript设计模式 接口介绍 2019-09-23
- 前端笔记之微信小程序(二){{}}插值和MVVM模式&数 2019-08-14
- [Vue 牛刀小试]:第十五章 - 传统开发模式下的 axios 使用入 2019-08-14
- [JS设计模式]:观察者模式(即发布-订阅者模式)(4) 2019-08-14
- vue history 模式打包部署在域名的二级目录的配置指南 2019-08-14
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash