时间:2021-05-26
废话不多说,直接上代码
//发布订阅模式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 发布订阅模式的实例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了JS模式之简单的订阅者和发布者模式。分享给大家供大家参考。具体如下:partenvarsingletonTest=SingletonTest.ge
本文实例讲述了js设计模式之代理模式及订阅发布模式。分享给大家供大家参考,具体如下:为啥将两种模式放在一起呢?因为这样文章比较长啊。写博客的目的我觉得首要目的是
我想到使用Redis的订阅发布模式是用来解决推送问题的~。对于概念性的叙述,多多少少还是要提一下的:什么是Redis发布订阅?Redis发布订阅是一种消息通信模
一、前言数据双向绑定作为Vue核心功能之一,其实现原理主要分为两部分:数据劫持发布订阅模式本篇文章主要介绍Vue实现数据劫持的思路,下一篇则会介绍发布订阅模式的
发布者订阅者模式,是一种很常见的模式,比如:一、买卖房子生活中的买房,卖房,中介就构成了一个发布订阅者模式,买房的人,一般需要的是房源,价格,使用面积等信息,他