深入理解JavaScript系列(30):設(shè)計(jì)模式之外觀模式詳解
介紹
外觀模式(Facade)為子系統(tǒng)中的一組接口提供了一個(gè)一致的界面,此模塊定義了一個(gè)高層接口,這個(gè)接口值得這一子系統(tǒng)更加容易使用。
正文
外觀模式不僅簡(jiǎn)化類(lèi)中的接口,而且對(duì)接口與調(diào)用者也進(jìn)行了解耦。外觀模式經(jīng)常被認(rèn)為開(kāi)發(fā)者必備,它可以將一些復(fù)雜操作封裝起來(lái),并創(chuàng)建一個(gè)簡(jiǎn)單的接口用于調(diào)用。
外觀模式經(jīng)常被用于JavaScript類(lèi)庫(kù)里,通過(guò)它封裝一些接口用于兼容多瀏覽器,外觀模式可以讓我們間接調(diào)用子系統(tǒng),從而避免因直接訪問(wèn)子系統(tǒng)而產(chǎn)生不必要的錯(cuò)誤。
外觀模式的優(yōu)勢(shì)是易于使用,而且本身也比較輕量級(jí)。但也有缺點(diǎn) 外觀模式被開(kāi)發(fā)者連續(xù)使用時(shí)會(huì)產(chǎn)生一定的性能問(wèn)題,因?yàn)樵诿看握{(diào)用時(shí)都要檢測(cè)功能的可用性。
下面是一段未優(yōu)化過(guò)的代碼,我們使用了外觀模式通過(guò)檢測(cè)瀏覽器特性的方式來(lái)創(chuàng)建一個(gè)跨瀏覽器的使用方法。
var addMyEvent = function (el, ev, fn) {
if (el.addEventListener) {
el.addEventListener(ev, fn, false);
} else if (el.attachEvent) {
el.attachEvent('on' + ev, fn);
} else {
el['on' + ev] = fn;
}
};
再來(lái)一個(gè)簡(jiǎn)單的例子,說(shuō)白了就是用一個(gè)接口封裝其它的接口:
var mobileEvent = {
// ...
stop: function (e) {
e.preventDefault();
e.stopPropagation();
}
// ...
};
總結(jié)
那么何時(shí)使用外觀模式呢?一般來(lái)說(shuō)分三個(gè)階段:
首先,在設(shè)計(jì)初期,應(yīng)該要有意識(shí)地將不同的兩個(gè)層分離,比如經(jīng)典的三層結(jié)構(gòu),在數(shù)據(jù)訪問(wèn)層和業(yè)務(wù)邏輯層、業(yè)務(wù)邏輯層和表示層之間建立外觀Facade。
其次,在開(kāi)發(fā)階段,子系統(tǒng)往往因?yàn)椴粩嗟闹貥?gòu)演化而變得越來(lái)越復(fù)雜,增加外觀Facade可以提供一個(gè)簡(jiǎn)單的接口,減少他們之間的依賴(lài)。
第三,在維護(hù)一個(gè)遺留的大型系統(tǒng)時(shí),可能這個(gè)系統(tǒng)已經(jīng)很難維護(hù)了,這時(shí)候使用外觀Facade也是非常合適的,為系系統(tǒng)開(kāi)發(fā)一個(gè)外觀Facade類(lèi),為設(shè)計(jì)粗糙和高度復(fù)雜的遺留代碼提供比較清晰的接口,讓新系統(tǒng)和Facade對(duì)象交互,F(xiàn)acade與遺留代碼交互所有的復(fù)雜工作。
參考:大話設(shè)計(jì)模式
- 設(shè)計(jì)模式中的facade外觀模式在JavaScript開(kāi)發(fā)中的運(yùn)用
- JavaScript設(shè)計(jì)模式之外觀模式介紹
- JavaScript設(shè)計(jì)模式之外觀模式實(shí)例
- javascript設(shè)計(jì)模式 – 裝飾模式原理與應(yīng)用實(shí)例分析
- javascript設(shè)計(jì)模式 – 組合模式原理與應(yīng)用實(shí)例分析
- javascript設(shè)計(jì)模式 – 橋接模式原理與應(yīng)用實(shí)例分析
- javascript設(shè)計(jì)模式 – 適配器模式原理與應(yīng)用實(shí)例分析
- JS中間件設(shè)計(jì)模式的深入探討與實(shí)例分析
- javascript設(shè)計(jì)模式 – 建造者模式原理與應(yīng)用實(shí)例分析
- javascript設(shè)計(jì)模式 – 原型模式原理與應(yīng)用實(shí)例分析
- javascript設(shè)計(jì)模式 – 外觀模式原理與用法實(shí)例分析
相關(guān)文章
Javascript核心讀書(shū)有感之語(yǔ)言核心
本節(jié)是javascript語(yǔ)言的一個(gè)快速預(yù)覽,也是本書(shū)的第一部分快速預(yù)覽。有想閱讀此書(shū)的小伙伴,建議先讀下本系列文章。2015-02-02
JavaScript事件處理器中的event參數(shù)使用介紹
當(dāng)一個(gè)事件處理器被觸發(fā)時(shí),名為Event的類(lèi)實(shí)例會(huì)作為第一個(gè)參數(shù)傳入處理器中,下面為大家詳細(xì)介紹下它的應(yīng)用2013-05-05
javascript 繼承學(xué)習(xí)心得總結(jié)
下面小編就為大家?guī)?lái)一篇javascript 繼承學(xué)習(xí)心得總結(jié)。小編覺(jué)得挺不錯(cuò)的?,F(xiàn)在分享給大家。給大家做個(gè)參考2016-03-03
JavaScript函數(shù)中上下文有哪些規(guī)則
上下文是從英文context翻譯過(guò)來(lái),指的是一種環(huán)境。在軟件工程中,上下文是一種屬性的有序序列,它們?yōu)轳v留在環(huán)境內(nèi)的對(duì)象定義環(huán)境。在對(duì)象的激活過(guò)程中創(chuàng)建上下文,對(duì)象被配置為要求某些自動(dòng)服務(wù)。又比如計(jì)算機(jī)技術(shù)中,相對(duì)于進(jìn)程而言,上下文就是進(jìn)程執(zhí)行時(shí)的環(huán)境2021-10-10
JavaScript學(xué)習(xí)筆記(一) js基本語(yǔ)法
JavaScript學(xué)習(xí)筆記(一) js基本語(yǔ)法,想要學(xué)習(xí)js的朋友可以參考下。2011-10-10
簡(jiǎn)介JavaScript中的setTime()方法的使用
這篇文章主要介紹了簡(jiǎn)介JavaScript中的setTime()方法的使用,是JS入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-06-06

