深入理解JavaScript系列(27):設計模式之建造者模式詳解
來源:易賢網 閱讀:864 次 日期:2015-03-06 10:49:44
溫馨提示:易賢網小編為您整理了“深入理解JavaScript系列(27):設計模式之建造者模式詳解”,方便廣大網友查閱!

這篇文章主要介紹了深入理解JavaScript系列(27):設計模式之建造者模式詳解,建造者模式可以將一個復雜對象的構建與其表示相分離,使得同樣的構建過程可以創建不同的表示,需要的朋友可以參考下

介紹

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

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

正文

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

代碼如下:

function getBeerById(id, callback) {

// 使用ID來請求數據,然后返回數據.

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);

});

}

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

同樣再來一個jQuery的例子:

代碼如下:

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

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

總結

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

更多信息請查看IT技術專欄

更多信息請查看腳本欄目
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
未满十八18勿进黄网站免费看