JavaScript設(shè)計(jì)模式發(fā)布訂閱模式
前言
發(fā)布訂閱設(shè)計(jì)模式是和觀察者設(shè)計(jì)模式基本上相同,但是他們兩個(gè)設(shè)計(jì)模式不同的是發(fā)布訂閱者擁有一個(gè)事件處理中心而觀察者并沒(méi)有
比如,我們利用訂閱者設(shè)計(jì)模式去監(jiān)聽(tīng)一個(gè)對(duì)象的改變,可以給對(duì)象改變的方法添加多個(gè)行為以及一個(gè)行為添加多個(gè)方法進(jìn)行處理
發(fā)布訂閱設(shè)計(jì)模式
發(fā)布訂閱設(shè)計(jì)模式只需要一個(gè)類(lèi),類(lèi)中擁有一個(gè)事件中心管理這行為的任務(wù)對(duì)列,我們利用這個(gè)構(gòu)造函數(shù)創(chuàng)建一個(gè)實(shí)例,在進(jìn)行模擬一個(gè)addEventListener()事件,進(jìn)行觸發(fā)事件中心行為上任務(wù)對(duì)列的方法
我們來(lái)舉一個(gè)訂閱者設(shè)計(jì)模式的例子:
- 小明去買(mǎi)書(shū)
去書(shū)店問(wèn)店員,店員說(shuō)沒(méi)有就回家,過(guò)一會(huì)再去問(wèn)問(wèn),以此往復(fù),直到買(mǎi)到
- 小紅去買(mǎi)書(shū)
去書(shū)店問(wèn)店員,店員說(shuō)沒(méi)有就會(huì)留下一個(gè)聯(lián)系電話給店員,有了書(shū)店員就會(huì)聯(lián)系小紅,過(guò)去買(mǎi)書(shū)
小紅這種就是發(fā)布訂閱設(shè)計(jì)模式的操作,首先給店員留下電話號(hào)是往行為的任務(wù)隊(duì)列中添加方法,店員打電話是觸發(fā)了書(shū)到了的行為
訂閱者類(lèi)有個(gè)一個(gè)屬性:
- 事件中心,用于存放訂閱者行為的任務(wù)對(duì)列
訂閱者類(lèi)中有三個(gè)方法,分別為:
- 往任務(wù)隊(duì)列中添加函數(shù)
- 觸發(fā)任務(wù)隊(duì)列里的函數(shù)
- 刪除任務(wù)隊(duì)列里的函數(shù)
創(chuàng)建類(lèi),類(lèi)中有一個(gè)對(duì)象,該對(duì)象就是事件中心,用于存儲(chǔ)行為的任務(wù)隊(duì)列
class Subscribe {
constructor() {
// 事件中心
this.task = {};
}
}
添加觸發(fā)任務(wù)隊(duì)列函數(shù)方法:
// type 行為
trigger(type) {
// 判斷當(dāng)前的行為是否真的訂閱過(guò)
if (!(type in this.task)) return;
// 行為訂閱過(guò)直接進(jìn)行執(zhí)行該行為上的方法
this.task[type].map(callbak => callbak())
}
添加任務(wù)隊(duì)列中刪除函數(shù)方法:
// type 行為
// callback 函數(shù)
del(type, callback) {
// 判斷當(dāng)前的行為是否真的訂閱過(guò)
if (!(type in this.task)) return;
// 過(guò)濾出當(dāng)前想要?jiǎng)h除的函數(shù)
this.task[type].filter(val => val != callback);
}
添加任務(wù)隊(duì)列中添加函數(shù)方法:
// type 是行為
// callback 是行為發(fā)生時(shí)候觸發(fā)的函數(shù)
add(type, callback) {
// 判斷type這個(gè)行為是否已經(jīng)被注冊(cè)過(guò)了,沒(méi)有則注冊(cè)
if (!(type in this.task)) {
// 沒(méi)有注冊(cè)過(guò)給一個(gè)空數(shù)組
this.task[type] = [];
};
//往該行為的任務(wù)隊(duì)列添加方法
this.task[type].push(callback)
}
創(chuàng)建一個(gè)訂閱者實(shí)例并添加行為和對(duì)行為的任務(wù)對(duì)列增刪方法
// 創(chuàng)建訂閱者實(shí)例
const per = new Subscribe();
// 給訂閱者實(shí)例添加行為和出現(xiàn)行為時(shí)觸發(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è)計(jì)模式如果添加了很多事件會(huì)增加內(nèi)存的消耗并且程序難以維護(hù)以及難以判斷事件來(lái)源
到此這篇關(guān)于JavaScript設(shè)計(jì)模式發(fā)布訂閱模式的文章就介紹到這了,更多相關(guān)JavaScript 發(fā)布訂閱模式內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
微信小程序?qū)崿F(xiàn)的貪吃蛇游戲【附源碼下載】
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)的貪吃蛇游戲,結(jié)合實(shí)例形式分析了微信小程序?qū)崿F(xiàn)貪吃蛇游戲功能的相關(guān)界面布局與代碼邏輯操作技巧,并附帶源碼供讀者下載參考,需要的朋友可以參考下2018-01-01
查看QQ是否在線狀態(tài)的網(wǎng)頁(yè)代碼
這個(gè)其實(shí)就是利用qq官方提供的東西,簡(jiǎn)單的通過(guò)圖片來(lái)測(cè)試是否在線,隱身也是不在線狀態(tài)。純粹學(xué)習(xí)使用。2010-04-04
前端知識(shí)點(diǎn)之Javascript選擇輸入框confirm用法
這篇文章主要介紹了JavaScript中的confirm方法的基本用法、功能特點(diǎn)、注意事項(xiàng)及常見(jiàn)用途,文中通過(guò)代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用js具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2025-02-02
js實(shí)現(xiàn)輪播圖效果 z-index實(shí)現(xiàn)輪播圖
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)輪播圖效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-01-01
重載toString實(shí)現(xiàn)JS HashMap分析
用過(guò)Java的都知道,里面有個(gè)功能強(qiáng)大的數(shù)據(jù)結(jié)構(gòu)——HashMap,它能提供鍵與值的對(duì)應(yīng)訪問(wèn)。不過(guò)熟悉JS的朋友也會(huì)說(shuō),JS里面到處都是hashmap,因?yàn)槊總€(gè)對(duì)象都提供了map[key]的訪問(wèn)形式。2011-03-03
javascript設(shè)計(jì)模式 – 簡(jiǎn)單工廠模式原理與應(yīng)用實(shí)例分析
這篇文章主要介紹了javascript設(shè)計(jì)模式 – 簡(jiǎn)單工廠模式,結(jié)合實(shí)例形式分析了javascript簡(jiǎn)單工廠模式基本概念、原理、定義、應(yīng)用場(chǎng)景及操作注意事項(xiàng),需要的朋友可以參考下2020-04-04
原生JS實(shí)現(xiàn)Ajax跨域請(qǐng)求flask響應(yīng)內(nèi)容
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)Ajax跨域請(qǐng)求flask響應(yīng)內(nèi)容,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10
JavaScript圖片url地址轉(zhuǎn)base64簡(jiǎn)單示例
這篇文章主要給大家介紹了關(guān)于JavaScript圖片url地址轉(zhuǎn)base64的相關(guān)資料,圖片URL轉(zhuǎn)Base64是把圖片URL轉(zhuǎn)化為一個(gè)以base64編碼的字符串格式,使得圖片可以直接在HTML或CSS中使用,需要的朋友可以參考下2023-10-10
輕松實(shí)現(xiàn)js彈框顯示選項(xiàng)
這篇文章主要為大家詳細(xì)介紹了js輕松實(shí)現(xiàn)彈框顯示選項(xiàng)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09

