中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么用Javascript實現觀察者模式

發布時間:2021-12-03 09:03:29 來源:億速云 閱讀:139 作者:iii 欄目:開發技術

本篇內容主要講解“怎么用Javascript實現觀察者模式”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“怎么用Javascript實現觀察者模式”吧!

    什么是觀察者模式?

    • 觀察者模式一種設計模式。

    • 觀察者模式定義了對象間的一種 一對多 的依賴關系,當一個對象的狀態發生改變時,所有依賴于它的對象都將得到通知,并自動更新。

    • 簡單說明,在觀察者模式中,有兩個模型,一個觀察者(observer)和一個被觀察者(Observed)。當被觀察者發生改變或變化時,會通知觀察者。

    場景模擬

    • 倘若即將到來雙11,想要在雙11購買商品的人就是觀察者(Observer)

    • 想要購買的商品就是被觀察者(Observed)

    • 為了更加形象,添加一個商家來改變商品的價格,商家也就是發布者(Publish)

    • 當雙11當天,商家(發布者(Publish))會修改商品(被觀察者(Observed))的價格,然后關注訂閱該商品的人(觀察者(Observer))就會收到信息通知。

    代碼實現

    //觀察者設計模式
    //發布者 -->商家
    var shopObj = {};
    //商品列表 [key:[]], key為商品名
    shopObj.list = [];
    //訂閱方法
    shopObj.listen = function ( key, fn) {// key是商品型號, fn這個函數就是訂閱的行為
        if (!this.list[key]) {
            this.list[key] = [];
        }
        this.list[key].push(fn);//往商品名為key的商品列表中添加訂閱
    }
    //發布消息方法
    shopObj.publish = function (key) {
        //var key = arguments[0];//如果不傳參數key,這樣也可以
        var fns = this.list[key];
        // for (var i = 0; i < fns.length; i++) {
            for(var i = 0 ,fn; fn = fns[i++];){
            //執行訂閱的函數fn  arguemnts儲存的所有實參
            // var fn = fns[i++];
            fn.apply(this, arguments)
        }
    }
    //A用戶添加訂閱
    shopObj.listen("華為", function (brand, model) {
        console.log( "A用戶收到:" + brand + model + "手機降價了");
    })
    //B用戶添加訂閱
    shopObj.listen("華為", function (brand, model) {
        console.log("B用戶收到:" + brand + model + "手機降價了");
    })
    //c用戶添加訂閱
    shopObj.listen("小米", function (brand, model) {
        console.log("C用戶收到:" + brand + model + "手機降價了");
    })
    //雙11 商家發布消息華為降價的信息
    shopObj.publish("華為", "p30");
    shopObj.publish("小米", "Mix4");

    怎么用Javascript實現觀察者模式

    重構代碼

    //觀察者設計模式
    var Eevent = {
        //商品列表 [key:[]], key為商品名
        list: [],
        //訂閱方法
        listen: function (key, fn) {// key是商品型號, fn這個函數就是訂閱的行為
            if (!this.list[key]) {
                this.list[key] = [];
            }
            this.list[key].push(fn);
        },
        //發布消息方法
        publish: function (key) {
            //var key = arguments[0];//如果不傳參數key,這樣也可以
            var fns = this.list[key];
            // for (var i = 0; i < fns.length; i++) {
            for (var i = 0, fn; fn = fns[i++];) {
                //執行訂閱的函數fn  arguemnts儲存的所有實參
                // var fn = fns[i++];
                fn.apply(this, arguments)
            }
        }
    }
    //觀察者對象初始化
    var initEvent = function (obj) {
        for (var i in Eevent) {
            obj[i] = Eevent[i];
        }
    }
    //發布者 -->商家
    var shopObj = {};
    initEvent(shopObj);
    //A用戶添加訂閱
    shopObj.listen("華為", function (brand, model) {
        console.log("A用戶收到:" + brand + model + "手機降價了");
    })
    //B用戶添加訂閱
    shopObj.listen("華為", function (brand, model) {
        console.log("B用戶收到:" + brand + model + "手機降價了");
    })
    //c用戶添加訂閱
    shopObj.listen("小米", function (brand, model) {
        console.log("C用戶收到:" + brand + model + "手機降價了");
    })
    //雙11 商家發布消息華為降價的信息
    shopObj.publish("華為", "p30");
    shopObj.publish("小米", "Mix4");

    怎么用Javascript實現觀察者模式

    到此,相信大家對“怎么用Javascript實現觀察者模式”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    稷山县| 台南市| 孝昌县| 大洼县| 永康市| 孟连| 安仁县| 锡林浩特市| 高阳县| 大渡口区| 海伦市| 仁化县| 昭通市| 邯郸县| 绩溪县| 澄江县| 民勤县| 托克逊县| 海兴县| 澳门| 井陉县| 东港市| 龙游县| 肇东市| 专栏| 苏州市| 静宁县| 呼玛县| 阜平县| 启东市| 安顺市| 伊川县| 镇坪县| 浦县| 兴隆县| 登封市| 深水埗区| 荆门市| 宝鸡市| 深州市| 含山县|