JavaScript設(shè)計模式發(fā)布訂閱模式
前言
發(fā)布訂閱設(shè)計模式是和觀察者設(shè)計模式基本上相同,但是他們兩個設(shè)計模式不同的是發(fā)布訂閱者擁有一個事件處理中心而觀察者并沒有
比如,我們利用訂閱者設(shè)計模式去監(jiān)聽一個對象的改變,可以給對象改變的方法添加多個行為以及一個行為添加多個方法進(jìn)行處理
發(fā)布訂閱設(shè)計模式
發(fā)布訂閱設(shè)計模式只需要一個類,類中擁有一個事件中心管理這行為的任務(wù)對列,我們利用這個構(gòu)造函數(shù)創(chuàng)建一個實例,在進(jìn)行模擬一個addEventListener()事件,進(jìn)行觸發(fā)事件中心行為上任務(wù)對列的方法
我們來舉一個訂閱者設(shè)計模式的例子:
- 小明去買書
去書店問店員,店員說沒有就回家,過一會再去問問,以此往復(fù),直到買到
- 小紅去買書
去書店問店員,店員說沒有就會留下一個聯(lián)系電話給店員,有了書店員就會聯(lián)系小紅,過去買書
小紅這種就是發(fā)布訂閱設(shè)計模式的操作,首先給店員留下電話號是往行為的任務(wù)隊列中添加方法,店員打電話是觸發(fā)了書到了的行為
訂閱者類有個一個屬性:
- 事件中心,用于存放訂閱者行為的任務(wù)對列
訂閱者類中有三個方法,分別為:
- 往任務(wù)隊列中添加函數(shù)
- 觸發(fā)任務(wù)隊列里的函數(shù)
- 刪除任務(wù)隊列里的函數(shù)
創(chuàng)建類,類中有一個對象,該對象就是事件中心,用于存儲行為的任務(wù)隊列
class Subscribe { constructor() { // 事件中心 this.task = {}; } }
添加觸發(fā)任務(wù)隊列函數(shù)方法:
// type 行為 trigger(type) { // 判斷當(dāng)前的行為是否真的訂閱過 if (!(type in this.task)) return; // 行為訂閱過直接進(jìn)行執(zhí)行該行為上的方法 this.task[type].map(callbak => callbak()) }
添加任務(wù)隊列中刪除函數(shù)方法:
// type 行為 // callback 函數(shù) del(type, callback) { // 判斷當(dāng)前的行為是否真的訂閱過 if (!(type in this.task)) return; // 過濾出當(dāng)前想要刪除的函數(shù) this.task[type].filter(val => val != callback); }
添加任務(wù)隊列中添加函數(shù)方法:
// type 是行為 // callback 是行為發(fā)生時候觸發(fā)的函數(shù) add(type, callback) { // 判斷type這個行為是否已經(jīng)被注冊過了,沒有則注冊 if (!(type in this.task)) { // 沒有注冊過給一個空數(shù)組 this.task[type] = []; }; //往該行為的任務(wù)隊列添加方法 this.task[type].push(callback) }
創(chuàng)建一個訂閱者實例并添加行為和對行為的任務(wù)對列增刪方法
// 創(chuàng)建訂閱者實例 const per = new Subscribe(); // 給訂閱者實例添加行為和出現(xiàn)行為時觸發(fā)的方法 per.add('click', handA) per.add('click', handB) per.add('click', handC) // 根據(jù)行為進(jìn)行觸發(fā)方法 per.trigger('click') // 根據(jù)行為和方法進(jìn)行刪除 per.del('click', handC) // 方法 function handA() { console.log('clickA'); } // 方法 function handB() { console.log('clickB'); } // 方法 function handC() { console.log('clickC'); }
訂閱者設(shè)計模式如果添加了很多事件會增加內(nèi)存的消耗并且程序難以維護(hù)以及難以判斷事件來源
到此這篇關(guān)于JavaScript設(shè)計模式發(fā)布訂閱模式的文章就介紹到這了,更多相關(guān)JavaScript 發(fā)布訂閱模式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript實現(xiàn)倒計時跳轉(zhuǎn)頁面功能【實用】
本文分享了JavaScript實現(xiàn)倒計時跳轉(zhuǎn)頁面功能的具體實例代碼,頁面代碼簡單,直接拷貝就能運行,頁面可以自己美化下哦。需要的朋友一起來看下吧2016-12-12javascript判斷機(jī)器是否聯(lián)網(wǎng)的2種方法
只有機(jī)器已經(jīng)聯(lián)網(wǎng)以后,web應(yīng)用才能啟動,下面使用javascript判斷機(jī)器是否聯(lián)網(wǎng),具體判斷代碼如下,有此需求的朋友可以參考下2013-08-08