国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

深入理解JavaScript系列(27):設計模式之建造者模式詳解

2019-11-20 13:02:42
字體:
來源:轉載
供稿:網友

介紹

在軟件系統(tǒng)中,有時候面臨著“一個復雜對象”的創(chuàng)建工作,其通常由各個部分的子對象用一定的算法構成;由于需求的變化,這個復雜對象的各個部分經常面臨著劇烈的變化,但是將它們組合在一起的算法確相對穩(wěn)定。如何應對這種變化?如何提供一種“封裝機制”來隔離出“復雜對象的各個部分”的變化,從而保持系統(tǒng)中的“穩(wěn)定構建算法”不隨著需求改變而改變?這就是要說的建造者模式。

建造者模式可以將一個復雜對象的構建與其表示相分離,使得同樣的構建過程可以創(chuàng)建不同的表示。也就是說如果我們用了建造者模式,那么用戶就需要指定需要建造的類型就可以得到它們,而具體建造的過程和細節(jié)就不需要知道了。

正文

這個模式相對來說比較簡單,先上代碼,然后再解釋

復制代碼 代碼如下:

function getBeerById(id, callback) {
    // 使用ID來請求數(shù)據,然后返回數(shù)據.
    asyncRequest('GET', 'beer.uri?id=' + id, function (resp) {
        // callback調用 response
        callback(resp.responseText);
    });
}

var el = document.querySelector('#test');
el.addEventListener('click', getBeerByIdBridge, false);

function getBeerByIdBridge(e) {
    getBeerById(this.id, function (beer) {
        console.log('Requested Beer: ' + beer);
    });
}

根據建造者的定義,表相即是回調,也就是說獲取數(shù)據以后如何顯示和處理取決于回調函數(shù),相應地回調函數(shù)在處理數(shù)據的時候不需要關注是如何獲取數(shù)據的,同樣的例子也可以在jquery的ajax方法里看到,有很多回調函數(shù)(比如success, error回調等),主要目的就是職責分離。

同樣再來一個jQuery的例子:

復制代碼 代碼如下:

$('<div class= "foo"> bar </div>');

我們只需要傳入要生成的HTML字符,而不需要關系具體的HTML對象是如何生產的。

總結

建造者模式主要用于“分步驟構建一個復雜的對象”,在這其中“分步驟”是一個穩(wěn)定的算法,而復雜對象的各個部分則經常變化,其優(yōu)點是:建造者模式的“加工工藝”是暴露的,這樣使得建造者模式更加靈活,并且建造者模式解耦了組裝過程和創(chuàng)建具體部件,使得我們不用去關心每個部件是如何組裝的。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 乌海市| 郴州市| 永仁县| 长阳| 东宁县| 新宁县| 政和县| 清河县| 永川市| 绥阳县| 余江县| 连城县| 吉木乃县| 巴青县| 尼玛县| 衡山县| 颍上县| 通化县| 德阳市| 睢宁县| 旺苍县| 运城市| 景洪市| 富锦市| 府谷县| 体育| 满城县| 调兵山市| 柘城县| 西城区| 楚雄市| 永新县| 连江县| 临漳县| 当雄县| 临泉县| 喀喇沁旗| 全南县| 阿拉善右旗| 乌海市| 循化|