欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript設(shè)計模式發(fā)布訂閱模式

 更新時間:2022年06月23日 14:40:56   作者:? 前端若水?  ?  
這篇文章主要介紹了JavaScript設(shè)計模式發(fā)布訂閱模式,發(fā)布訂閱設(shè)計模式是和觀察者設(shè)計模式基本上相同,但是他們兩個設(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)文章

  • js實現(xiàn)碰撞檢測

    js實現(xiàn)碰撞檢測

    這篇文章主要為大家詳細(xì)介紹了js實現(xiàn)碰撞檢測,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • Bootstrap4如何定制自己的顏色和風(fēng)格

    Bootstrap4如何定制自己的顏色和風(fēng)格

    這篇文章主要介紹了Bootstrap4如何定制自己的顏色和風(fēng)格,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • 微信小程序自定義地址組件

    微信小程序自定義地址組件

    這篇文章主要為大家詳細(xì)介紹了微信小程序自定義地址組件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 關(guān)于樹形菜單 Checkbox的全選

    關(guān)于樹形菜單 Checkbox的全選

    js樹形菜單全選
    2008-07-07
  • JS中兩個數(shù)組對象篩選方法

    JS中兩個數(shù)組對象篩選方法

    這篇文章主要介紹了JS中兩個數(shù)組對象篩選,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-12-12
  • weui上傳多圖片,壓縮,base64編碼的示例代碼

    weui上傳多圖片,壓縮,base64編碼的示例代碼

    這篇文章主要介紹了weui上傳多圖片,壓縮,base64編碼,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • Bootstrap每天必學(xué)之下拉菜單

    Bootstrap每天必學(xué)之下拉菜單

    Bootstrap每天必學(xué)之下拉菜單,本文講解的就是大家最為常用的下拉菜單操作,感興趣的小伙伴們可以參考一下
    2015-11-11
  • HTTP?HEAD請求的使用場合實例詳解

    HTTP?HEAD請求的使用場合實例詳解

    這篇文章主要為大家介紹了HTTP?HEAD請求的使用場合實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • JavaScript實現(xiàn)倒計時跳轉(zhuǎn)頁面功能【實用】

    JavaScript實現(xiàn)倒計時跳轉(zhuǎn)頁面功能【實用】

    本文分享了JavaScript實現(xiàn)倒計時跳轉(zhuǎn)頁面功能的具體實例代碼,頁面代碼簡單,直接拷貝就能運行,頁面可以自己美化下哦。需要的朋友一起來看下吧
    2016-12-12
  • javascript判斷機(jī)器是否聯(lián)網(wǎng)的2種方法

    javascript判斷機(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

最新評論