欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

javascript發(fā)布訂閱模式的示例分析-創(chuàng)新互聯(lián)

這篇文章主要介紹javascript發(fā)布訂閱模式的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

五河ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)公司的ssl證書銷售渠道,可以享受市場價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:13518219792(備注:SSL證書合作)期待與您的合作!

發(fā)布訂閱模式

事件發(fā)布/訂閱模式 (PubSub) 在異步編程中幫助我們完成更松的解耦,甚至在 MVC、MVVC 的架構(gòu)中以及設(shè)計(jì)模式中也少不了發(fā)布-訂閱模式的參與。

優(yōu)點(diǎn):在異步編程中實(shí)現(xiàn)更深的解耦

缺點(diǎn):如果過多的使用發(fā)布訂閱模式,會增加維護(hù)的難度

實(shí)現(xiàn)發(fā)布訂閱模式

var Event = function() {
    this.obj = {}
}

Event.prototype.on = function(eventType,fn) {
    if(!this.obj[eventType]) {
        this.obj[eventType] = []
    }
    this.obj[eventType].push(fn)
}

Event.prototype.emit = function() {
    // 取第一個(gè)參數(shù),作為eventType
    var eventType = Array.prototype.shift.call(arguments);
    //  獲取事件數(shù)組
    var arr = this.obj[eventType];
    var len = arr.length;
    // 循環(huán)數(shù)組,一次執(zhí)行其中的函數(shù)
    for(var i=0;i<len;i++) {
        // 直接調(diào)用arr[i],其this指向?yàn)閡ndefined(嚴(yán)格模式下)
        // 因此用apply將this指向arr[i]
        // 數(shù)組shift函數(shù)取出第一個(gè)參數(shù),將剩下的參數(shù)傳入函數(shù)中
        arr[i].apply(arr[i],arguments)
    }
}

var ev = new Event()
ev.on('click',function(a) {  // 訂閱
    console.log(a)
})

ev.emit('click',1)   // 發(fā)布

以上代碼只能實(shí)現(xiàn)先訂閱,再發(fā)布。直接發(fā)布就會報(bào)錯(cuò)。如何實(shí)現(xiàn)可以先發(fā)布,然后訂閱?

var Event = function() {
    this.obj = {};
    this.cacheList = [];
}

Event.prototype.emit = function() {
    const args = arguments;  //函數(shù)參數(shù)
    const that = this;  //this指向,保持cache函數(shù)的this指向
    function cache() {
        var eventType = Array.prototype.shift.call(arg)
        var arr = that.obj[eventType]
        for (let i = 0; i < arr.length; i++) {
          arr[i].apply(arr[i], arg)
        }
    }
    this.cacheList.push(cache)  // 采用閉包,保持對emit函數(shù)中參數(shù)和that的引用
}

Event.prototype.on = function(eventType,fn) {
    if(!this.obj[eventType]) {
        this.obj[eventType] = []
    }
    this.obj[eventType].push(fn)
    // 在訂閱函數(shù)中執(zhí)行emit函數(shù)中緩存的函數(shù)
    for (let i = 0; i < this.cacheList.length; i++) {
        this.cacheList[i]()
    }
}

改成這樣后就實(shí)現(xiàn)了先發(fā)布函數(shù),再訂閱的過程。但是也只能先發(fā)布,然后再訂閱,反過來就行不通。

以上是“javascript發(fā)布訂閱模式的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

網(wǎng)頁標(biāo)題:javascript發(fā)布訂閱模式的示例分析-創(chuàng)新互聯(lián)
文章地址:http://www.aaarwkj.com/article36/cchopg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗(yàn)、云服務(wù)器、品牌網(wǎng)站設(shè)計(jì)品牌網(wǎng)站建設(shè)、品牌網(wǎng)站制作App設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)
美女口爆吞精一区二区| 亚洲精品中文一区二区三区| 无套内射精品一区二区| av网址在线免费观看| 国产成人国产精品国产三级| 97公开视频在线观看| 国产激情av网站在线观看 | 厕所偷拍视频一区二区三区| 亚洲一区二区三区 日韩精品| 午夜久久精品国产亚洲av| av午夜精品一区二区| 欧洲一区二区在线激情| 欧美日韩亚洲国产精品视频| 国产精品国产精品无卡区| 中文字幕av在线日韩| 国产精品一区二区麻豆本子| 成人黄色18免费网站| 精品女同一区二区三区网站| 午夜草草视频在线观看| 日韩欧美精品在线观看免费| 香蕉视频网站欧美一区| 亚洲综合色婷婷七月丁香| 久久精品国产亚洲av不丁香| 日韩精品欧美精品视频一区| 国产精品中文字幕有码| 亚洲熟妇av一区二区三区l| 亚洲最大色网在线观看| 亚洲午夜经典一区二区日韩| 亚洲毛片在线免费播放| 国产综合亚洲欧美日韩在线| 中文字幕乱码人妻一区| 午夜日本大胆裸体艺术| 国产中文字二暮区2021综合| 国产午夜精品一区二区三区| 丰满人妻一区二区三区色| 日本一区二区在线观看视频| 九九视频免费观看91| 亚洲三区久久婷婷激情| 久久超碰一区二区三区| 亚洲欧美日韩一区二区视频| 国产精品一区二区国产激情久久|