摘要:發(fā)布訂閱模式觀察者模式發(fā)布訂閱模式也叫觀察者模式,這是一個一對多的關(guān)系,可以多個訂閱者訂閱同一個事件,當事件觸發(fā)時就會通知訂閱者去執(zhí)行訂閱時綁定的程序我舉個例子來解釋一下同學想在結(jié)婚的時候邀請好友來喝喜酒,這個邀請的名單其實就是訂閱事件
發(fā)布-訂閱模式/觀察者模式
發(fā)布-訂閱模式也叫觀察者模式,這是一個一對多的關(guān)系,可以多個訂閱者訂閱同一個事件,當事件觸發(fā)時就會通知訂閱者去執(zhí)行訂閱時綁定的程序;
我舉個例子來解釋一下:
A同學想在結(jié)婚的時候邀請好友B、C、D、E、F、G...來喝喜酒,這個邀請的名單其實就是訂閱事件
class Person extends EventEmitter{ constructor(){ super(); } } let A= new Person(); function drinkFn(){ console.log( `xxxx年xx月xx日來xx大酒店和我的喜酒!`) } A.on("結(jié)婚",drinkFn);
等到A同學要結(jié)婚的時候,他就會去通知他的好友XXX時間XX酒店過來喝酒,這個過程就是發(fā)布事件
A.emit("結(jié)婚");
以下是我的實現(xiàn)過程:
class EventEmitter { constructor(){ this._count=null; } //訂閱事件 on(type,callBack,flag){ //創(chuàng)建_events對象 if(!this._events){ this._events=Object.create(null); } // 判斷_events對象是否有type屬性 if(this._events[type]){ if(flag){ this._events[type].unshift(callBack) }else{ this._events[type].push(callBack) } }else{ this._events[type]=[callBack] } //type如果不是newListener類型,則執(zhí)行newListener對應的函數(shù) if(type!=="newListener"){ this._events["newListener"]&&this._events["newListener"].forEach(fn=>{ fn(type,callBack); }) } // 超出最大綁定事件限制提示 if(this._events[type].length>=this.getMaxListeners()){ console.log("超出最大綁定事件限制") } } //訂閱一次性事件 once(type,callBack,flag){ function warp(...argments){ callBack(...argments); this.removeListener(type,callBack) } warp.cb=callBack; this.on(type,warp,flag); } //發(fā)布事件 emit(type,...args){ if(this._events[type]){ this._events[type].forEach(fn => { fn.call(this,...args) }); } } // 獲取當前type事件的數(shù)組對象 listeners(type){ return this._events[type]||[]; } // 訂閱事件并在第一時間觸發(fā) prependListener(type,callBack){ this.on(type,callBack,true); } // 訂閱一次性事件并在第一時間觸發(fā) prependOnceListener(type,callBack){ this.once(type,callBack,true); } // 獲取當前實例所有的事件類型 eventNames(){ return Object.keys(this._events) } // 獲取當前type事件類型的長度 listenerCount(type){ if(this._events[type]){ return this._events[type].length }else{ return 0 } } // 移除type事件所有的執(zhí)行函數(shù) removeListener(type,callBack){ if(this._events[type]){ this._events[type]=this._events[type].filter(fn=>{ return callBack!=fn&&fn.cb!=callBack }) } } // 移除實例上所有的事件 removeAllListeners(){ this._events=Object.create(null) } // 獲取當前實例的最大事件綁定限制 getMaxListeners(){ return this._count ? this._count :EventEmitter.defaultMaxListeners; } // 設(shè)置當前實例的最大事件綁定限制 setMaxListeners(n){ this._count=n; } } // 設(shè)置默認的最大事件綁定限制 EventEmitter.defaultMaxListeners=10; module.exports=EventEmitter;
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/94370.html
摘要:期設(shè)計模式如何理解觀察者發(fā)布訂閱模式定義觀察者模式又叫發(fā)布訂閱模式,它定義了一種一對多的關(guān)系,讓多個觀察者對象同時監(jiān)聽某一個主題對象,這個主題對象的狀態(tài)發(fā)生變化時就會通知所有的觀察者對象,使得它們能夠自動更新自己生活實例理解你今天去看一個 20190411期 設(shè)計模式-如何理解觀察者(發(fā)布訂閱)模式? 定義: 觀察者模式又叫發(fā)布訂閱模式(Publish/Subscribe),它定義了一...
摘要:概念觀察者模式被廣泛地應用于客戶端編程中。所有的瀏覽器事件,等都是使用觀察者模式的例子。在觀察者模式中,一個對象訂閱另一個對象的指定活動并得到通知,而不是調(diào)用另一個對象的方法。此外,觀察者模式還可用于實現(xiàn)數(shù)據(jù)綁定。 概念 觀察者模式被廣泛地應用于JavaScript客戶端編程中。所有的瀏覽器事件(mouseover,keypress等)都是使用觀察者模式的例子。這種模式的另一個名字叫自...
摘要:觀察者模式簡介觀察者模式又稱發(fā)布訂閱模式,是一種最常用的設(shè)計模式之一了。其實瀏覽器的事件也是觀察者模式這里訂閱了的事件,當我們的鼠標點擊操作,事件發(fā)布,對應的就會執(zhí)行。包括在內(nèi)的,只要是支持事件響應的核心模塊都是的子類。 觀察者模式 簡介 觀察者模式又稱發(fā)布訂閱模式,是一種最常用的設(shè)計模式之一了。講道理,如果我們寫的不是稍微底層的代碼,可能不會用到它。 但是有了它會讓代碼更靈活,更加規(guī)...
摘要:觀察者模式介紹觀察者模式又稱發(fā)布訂閱模式,它定義對象間的一種一對多的依賴關(guān)系,當一個對象發(fā)生改變的時候,所依賴它的對象都能得到通知。關(guān)于內(nèi)部的觀察者模式可以參數(shù)這篇文檔。總結(jié)總之,觀察者模式在中的使用是非常廣泛的。 javascript觀察者模式 介紹 觀察者模式又稱發(fā)布-訂閱模式,它定義對象間的一種一對多的依賴關(guān)系,當一個對象發(fā)生改變的時候,所依賴它的對象都能得到通知。例如:我們訂閱...
摘要:我們在平時的工作中,總是會遇到老舊的系統(tǒng)以及老舊陳的代碼。弊端就是需要維護兩套代碼,理解兩套技術(shù)選型。那么問題就來了新的代碼如何和舊的代碼解耦新代碼我們當然是用新倉庫,新選擇,新打包工具。。。 我們在平時的工作中,總是會遇到老舊的系統(tǒng)以及老舊陳的代碼。他們是業(yè)務(wù)長年累月的積累,以及因為是三、四年前的技術(shù)選型造成的系統(tǒng)架構(gòu)的不合理以及繁瑣的代碼。維護這些代碼總是很頭疼,程序員遇到這樣的代...
閱讀 2491·2023-04-25 21:41
閱讀 1660·2021-09-22 15:17
閱讀 1931·2021-09-22 10:02
閱讀 2448·2021-09-10 11:21
閱讀 2587·2019-08-30 15:53
閱讀 1007·2019-08-30 15:44
閱讀 960·2019-08-30 13:46
閱讀 1149·2019-08-29 18:36