国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

JavaScript設計模式系列三:建造者模式

來源:懂視網 責編:小采 時間:2020-11-27 19:57:05
文檔

JavaScript設計模式系列三:建造者模式

JavaScript設計模式系列三:建造者模式:本篇文章給大家分享的是JavaScript設計模式系列三:建造者模式,有感興趣的朋友可以看一下建造者模式建造者模式(builder pattern)比較簡單,它屬于創建型模式的一種,將一個復雜的對象分解成多個簡單的對象來進行構建,將復雜的構建層與表示層分離,使得相
推薦度:
導讀JavaScript設計模式系列三:建造者模式:本篇文章給大家分享的是JavaScript設計模式系列三:建造者模式,有感興趣的朋友可以看一下建造者模式建造者模式(builder pattern)比較簡單,它屬于創建型模式的一種,將一個復雜的對象分解成多個簡單的對象來進行構建,將復雜的構建層與表示層分離,使得相

本篇文章給大家分享的是JavaScript設計模式系列三:建造者模式,有感興趣的朋友可以看一下

建造者模式

建造者模式(builder pattern)比較簡單,它屬于創建型模式的一種,將一個復雜的對象分解成多個簡單的對象來進行構建,將復雜的構建層與表示層分離,使得相同的構建過程可以創建不同的表示的模式便是建造者模式。

優點

  • 建造者模式的封裝性很好,對象本身與構建過程解耦。

  • 建造者模式很容易進行擴展。如果有新的需求,通過實現一個新的建造者類就可以完成。

  • 適用場景

    需要生成的對象具有復雜得內部結構;且內部屬性本身相互依賴


    建造者模式的代碼實現

    建造者模式主要有4個部分:product產品類、Builder建造者類、Director指揮者類、客戶。

    主要的流程是:
    1. 客戶提出需求。

    2. 指揮者根據用戶需求,指揮建造者去完成需求的各個部分。

    3. 建造者完成相應的部分。

    我們來看一下相應的代碼:
    產品類為一輛加工的空殼汽車。

    /**
     * 產品類:car 目前需要構建一輛車。
     */
    
    function car () {
     this.name = '',
     this.number = '',
     this.wheel = '',
     this.engine = ''
    }

    接下來看一下建造者類:

    /* 
    * 建造者類,里面有專門負責各個部分的工人
    */
    function carBuilder () {
     this.nameBuilder = function () {
     this.name = '很厲害的車'
     },
     this.numberBuilder = function () {
     this.number = '88888888'
     },
     this.wheelBuilder = function () {
     this.wheel = '高級橡膠做的輪子'
     },
     this.engineBuilder = function () {
     this.engine = '很厲害的引擎'
     },
     this.getCar = function () {
     var Car = new car()
     Car.name = this.name;
     Car.number= this.number;
     Car.wheel = this.wheel;
     Car.engine = this.engine;
     return Car;
     }
    }

    再這里我們可以看到各個部分的工人以及他們的工作,他們的各自的工作最終合并成一輛汽車。

    指揮者類:

    /**
     * 指揮者類,指揮各個部分的工人工作
     */
    function director () {
     this.action = function (builder) {
     builder.nameBuilder();
     builder.numberBuilder();
     builder.wheelBuilder();
     builder.engineBuilder();
     } 
    }

    最后就是使用方法:

    /**
     * 使用方法
     */
    
    var builder = new carBuilder();
    var director = new director();
    director.action(builder);
    var Car = builder.getCar();
    console.log(Car);

    最終客戶通過getCar方法得到了這輛車,并且不需要知道其中得建造細節。


    總結

    建造者模式主要用于“分布構建一個復雜的對象”,它很容易進行擴展。如果有新的需求,通過實現一個新的建造者類就可以完成,并且建造者模式解耦了對象本身與構建過程,使得我們不用關心具體的建造過程。

    相關推薦:

    JavaScript設計模式系列一:工廠模式

    JavaScript設計模式系列二:單例模式

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    JavaScript設計模式系列三:建造者模式

    JavaScript設計模式系列三:建造者模式:本篇文章給大家分享的是JavaScript設計模式系列三:建造者模式,有感興趣的朋友可以看一下建造者模式建造者模式(builder pattern)比較簡單,它屬于創建型模式的一種,將一個復雜的對象分解成多個簡單的對象來進行構建,將復雜的構建層與表示層分離,使得相
    推薦度:
    標簽: 模式 js 系列
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 国产一区系列在线观看 | 国产成人久久精品亚洲小说 | 亚洲原创区 | 亚欧精品在线观看 | 国产免费精彩视频 | 亚洲自拍偷拍区 | 福利视频一区二区三区 | 久久亚洲精品国产亚洲老地址 | 久久国产成人 | 亚洲色图第四页 | 精品国产91久久久久久久 | 亚洲一区二区精品视频 | 日本中文字幕有码 | 国产亚洲一区二区三区不卡 | 麻豆国产高清精品国在线 | 日韩在线播放一区 | www.色中色| 亚洲欧美视屏 | 伊人精品成人久久综合欧美 | 亚洲 自拍 另类 欧美 综合 | 亚洲第一页中文字幕 | 97国产精品欧美一区二区三区 | 综合精品欧美日韩国产在线 | 日韩欧美亚洲综合 | 亚洲 欧美 自拍 另类 欧美 | 欧美日韩另类国产 | 在线观看国产一区 | 亚洲欧洲日韩在线 | www.91麻豆 | 久久久久久91香蕉国产 | 伊人久久精品一区二区三区 | 国产毛片a| 另类国产精品一区二区 | 一区二区不卡久久精品 | 中国一级全黄的免费观看 | 国产精品久久久久久一区二区三区 | 2020精品极品国产色在线观看 | 欧美性一区二区三区五区 | 国产国拍亚洲精品永久不卡 | 欧美日韩亚洲高清不卡一区二区三区 | 亚洲欧美日韩精品永久在线 |