js 发布订阅模式
2017-09-09 17:39
477 查看
//发布订阅模式 class EventEmiter{ constructor(){ //维护一个对象 this._events={ } } on(eventName,callback){ if( this._events[eventName]){ //如果有就放一个新的 this._events[eventName].push(callback); }else{ //如果没有就创建一个数组 this._events[eventName]=[callback] } } emit(eventName,...rest){ if(this._events[eventName]){ //循环一次执行 this._events[eventName].forEach((item)=>{ item.apply(this,rest) }); } } removeListener(eventName,callback){ if(this._events[eventName]){ //当前数组和传递过来的callback相等则移除掉 this._events[eventName]= this._events[eventName].filter(item=>item!==callback); } } once(eventName,callback){ function one(){ //在one函数运行原来的函数,只有将one清空 callback.apply(this,arguments); //先绑定 执行后再删除 this.removeListener(eventName,one); } this.on(eventName,one); //此时emit触发会执行此函数,会给这个函数传递rest参数 } } class Man extends EventEmiter{} let man=new Man() function findGirl() { console.log('找新的女朋友') } function saveMoney() { console.log('省钱') } man.once('失恋',findGirl); //man.on('失恋',findGirl) //失恋 ,绑定一个函数方法 man.on('失恋',saveMoney)//失恋 ,绑定一个函数方法 man.removeListener('失恋',saveMoney); //移除一个函数方法 man.emit('失恋'); //绑定一次,触发多次,也只执行一次。触发后一次将数组中的哪一项删除掉下次触发就不会执行
相关文章推荐
- JS设计模式之发布订阅模式
- js 发布订阅/观察者模式
- js发布——订阅模式
- js 发布订阅模式的实例讲解
- Js实现订阅发布模式(让你的代码写得贼六)
- js设计模式之代理模式以及订阅发布模式
- JS模式之发布/订阅模式
- 【JS】发布/订阅模式
- js发布——订阅模式的通用实现及取消订阅
- js全局的发布——订阅模式
- js之发布 — 订阅模式
- JS设计模式 - 观察者模式与发布/订阅模式
- 学习笔记-js发布/订阅模式的简单实现
- js事件编程的发布/订阅模式(一对一关系)
- js 发布/订阅模式
- [转载]JS中什么是发布--订阅模式?
- js:发布-订阅模式
- js:发布订阅模式
- JS发布订阅模式
- node.js笔记之订阅发布设计模式