日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
觀察者模式和發(fā)布訂閱模式區(qū)別

之前一直對觀察者模式和發(fā)布訂閱模式的區(qū)別理解不深,正好這段時間在看vue源碼的分析,vue數(shù)據(jù)雙向綁定也用到了發(fā)布訂閱模式,于是又把這兩者探究了一番,今天做個筆記加強印象。

創(chuàng)新互聯(lián)建站是少有的成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計、營銷型企業(yè)網(wǎng)站、微信平臺小程序開發(fā)、手機APP,開發(fā)、制作、設(shè)計、買友情鏈接、推廣優(yōu)化一站式服務(wù)網(wǎng)絡(luò)公司,從2013年開始,堅持透明化,價格低,無套路經(jīng)營理念。讓網(wǎng)頁驚喜每一位訪客多年來深受用戶好評

觀察者模式和發(fā)布訂閱模式最大的區(qū)別就是發(fā)布訂閱模式有個事件調(diào)度中心。

從圖中可以看出,觀察者模式中觀察者和目標(biāo)直接進行交互,而發(fā)布訂閱模式中統(tǒng)一由調(diào)度中心進行處理,訂閱者和發(fā)布者互不干擾。這樣一方面實現(xiàn)了解耦,還有就是可以實現(xiàn)更細粒度的一些控制。比如發(fā)布者發(fā)布了很多消息,但是不想所有的訂閱者都接收到,就可以在調(diào)度中心做一些處理,類似于權(quán)限控制之類的。還可以做一些節(jié)流操作。

接下來看一下代碼實現(xiàn)
觀察者模式:

// 觀察者
class Observer {
    constructor() {

    }
    update(val) {

    }
}
// 觀察者列表
class ObserverList {
    constructor() {
        this.observerList = []
    }
    add(observer) {
        return this.observerList.push(observer);
    }
    remove(observer) {
        this.observerList = this.observerList.filter(ob => ob !== observer);
    }
    count() {
        return this.observerList.length;
    }
    get(index) {
        return this.observerList[index];
    }
}
// 目標(biāo)
class Subject {
    constructor() {
        this.observers = new ObserverList();
    }
    addObserver(observer) {
        this.observers.add(observer);
    }
    removeObserver(observer) {
        this.observers.remove(observer);
    }
    notify(...args) {
        let obCount = this.observers.count();
        for (let index = 0; index 

發(fā)布訂閱模式:

class PubSub {
    constructor() {
        this.subscribers = {}
    }
    subscribe(type, fn) {
        if (!Object.prototype.hasOwnProperty.call(this.subscribers, type)) {
          this.subscribers[type] = [];
        }
        
        this.subscribers[type].push(fn);
    }
    unsubscribe(type, fn) {
        let listeners = this.subscribers[type];
        if (!listeners || !listeners.length) return;
        this.subscribers[type] = listeners.filter(v => v !== fn);
    }
    publish(type, ...args) {
        let listeners = this.subscribers[type];
        if (!listeners || !listeners.length) return;
        listeners.forEach(fn => fn(...args));        
    }
}

let ob = new PubSub();
ob.subscribe('add', (val) => console.log(val));
ob.publish('add', 1);

從上面代碼可以看出,觀察者模式由具體目標(biāo)調(diào)度,每個被訂閱的目標(biāo)里面都需要有對觀察者的處理,會造成代碼的冗余。而發(fā)布訂閱模式則統(tǒng)一由調(diào)度中心處理,消除了發(fā)布者和訂閱者之間的依賴。

觀察者模式跟我們平時用的事件也有一定的關(guān)系,比如:

ele.addEventListener('click', () => {});

addEventListener就相當(dāng)于注冊了一個觀察者,當(dāng)觀察到‘click’事件的時候,作出一些處理。


新聞名稱:觀察者模式和發(fā)布訂閱模式區(qū)別
本文路徑:http://m.5511xx.com/article/dpjsdce.html