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

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

 更新時(shí)間:2022年06月23日 14:40:56   作者:? 前端若水?  ?  
這篇文章主要介紹了JavaScript設(shè)計(jì)模式發(fā)布訂閱模式,發(fā)布訂閱設(shè)計(jì)模式是和觀察者設(shè)計(jì)模式基本上相同,但是他們兩個(gè)設(shè)計(jì)模式不同的是發(fā)布訂閱者擁有一個(gè)事件處理中心而觀察者并沒有

前言

發(fā)布訂閱設(shè)計(jì)模式是和觀察者設(shè)計(jì)模式基本上相同,但是他們兩個(gè)設(shè)計(jì)模式不同的是發(fā)布訂閱者擁有一個(gè)事件處理中心而觀察者并沒有

比如,我們利用訂閱者設(shè)計(jì)模式去監(jiān)聽一個(gè)對象的改變,可以給對象改變的方法添加多個(gè)行為以及一個(gè)行為添加多個(gè)方法進(jìn)行處理

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

發(fā)布訂閱設(shè)計(jì)模式只需要一個(gè)類,類中擁有一個(gè)事件中心管理這行為的任務(wù)對列,我們利用這個(gè)構(gòu)造函數(shù)創(chuàng)建一個(gè)實(shí)例,在進(jìn)行模擬一個(gè)addEventListener()事件,進(jìn)行觸發(fā)事件中心行為上任務(wù)對列的方法

我們來舉一個(gè)訂閱者設(shè)計(jì)模式的例子:

  • 小明去買書

去書店問店員,店員說沒有就回家,過一會(huì)再去問問,以此往復(fù),直到買到

  • 小紅去買書

去書店問店員,店員說沒有就會(huì)留下一個(gè)聯(lián)系電話給店員,有了書店員就會(huì)聯(lián)系小紅,過去買書

小紅這種就是發(fā)布訂閱設(shè)計(jì)模式的操作,首先給店員留下電話號是往行為的任務(wù)隊(duì)列中添加方法,店員打電話是觸發(fā)了書到了的行為

訂閱者類有個(gè)一個(gè)屬性:

  • 事件中心,用于存放訂閱者行為的任務(wù)對列

訂閱者類中有三個(gè)方法,分別為:

  • 往任務(wù)隊(duì)列中添加函數(shù)
  • 觸發(fā)任務(wù)隊(duì)列里的函數(shù)
  • 刪除任務(wù)隊(duì)列里的函數(shù)

創(chuàng)建類,類中有一個(gè)對象,該對象就是事件中心,用于存儲(chǔ)行為的任務(wù)隊(duì)列

   class Subscribe {
            constructor() {
                // 事件中心
                this.task = {};
            }
      }

添加觸發(fā)任務(wù)隊(duì)列函數(shù)方法:

        // type 行為
            trigger(type) {
                // 判斷當(dāng)前的行為是否真的訂閱過
                if (!(type in this.task)) return;
                // 行為訂閱過直接進(jìn)行執(zhí)行該行為上的方法
                this.task[type].map(callbak => callbak())
            }

添加任務(wù)隊(duì)列中刪除函數(shù)方法:

            // type 行為
            // callback 函數(shù)
            del(type, callback) {
                // 判斷當(dāng)前的行為是否真的訂閱過
                if (!(type in this.task)) return;
                // 過濾出當(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)被注冊過了,沒有則注冊
                if (!(type in this.task)) {
                    // 沒有注冊過給一個(gè)空數(shù)組
                    this.task[type] = [];
                };
                //往該行為的任務(wù)隊(duì)列添加方法
                this.task[type].push(callback)
            }

創(chuàng)建一個(gè)訂閱者實(shí)例并添加行為和對行為的任務(wù)對列增刪方法

        // 創(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ù)以及難以判斷事件來源

到此這篇關(guān)于JavaScript設(shè)計(jì)模式發(fā)布訂閱模式的文章就介紹到這了,更多相關(guān)JavaScript 發(fā)布訂閱模式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論