JavaScript門面模式詳解
外部與一個子系統(tǒng)的通信必須通過一個系統(tǒng)的一個門面對象進行,這就是門面模式。
門面模式具備如下兩個角色:
1. 門面角色
客戶端可以調(diào)用這個角色方法,此角色中有子系統(tǒng)的應(yīng)用(知曉相關(guān)的(一個或多個)子系統(tǒng)的功能和責(zé)任)。本角色會將所有從客戶端發(fā)來的請求委派到相應(yīng)的子系統(tǒng)去。
2. 子系統(tǒng)角色
可以同時有一個或多個子系統(tǒng)。每一個子系統(tǒng)都不是一個單獨的類,而是一些類的集合。每一個子系統(tǒng)都可以被客戶端直接調(diào)用(這樣客戶端代碼會多),或被門面角色調(diào)用。子系統(tǒng)并不知道門面的存在,對于子系統(tǒng)而言,門面僅僅是另一個客戶端而已。
下面我們來看一個可以提現(xiàn)門面模式的簡單需求:主人為自己的寵物狗辦理的相應(yīng)的寵物領(lǐng)養(yǎng)證件
從這個簡單的需求中我們可以大致分析出我們需要:主人Person類和寵物狗Dog類 的一些相關(guān)信息
在下面的例子中國會涉及到接口的驗證,現(xiàn)在先將代碼貼出來
//(定義一個靜態(tài)方法來實現(xiàn)接口與實現(xiàn)類的直接檢驗
//靜態(tài)方法不要寫出Interface.prototype ,因為這是寫到接口的原型鏈上的
//我們要把靜態(tài)的函數(shù)直接寫到類層次上
//定義一個接口類
var Interface=function (name,methods) {//name:接口名字
if(arguments.length<2){
alert("必須是兩個參數(shù)")
}
this.name=name;
this.methods=[];//定義一個空數(shù)組裝載函數(shù)名
for(var i=0;i<methods.length;i++){
if(typeof methods[i]!="string"){
alert("函數(shù)名必須是字符串類型");
}else {
this.methods.push( methods[i]);
}
}
};
Interface.ensureImplement=function (object) {
if(arguments.length<2){
throw new Error("參數(shù)必須不少于2個")
return false;
}
for(var i=1;i<arguments.length;i++){
var inter=arguments[i];
//如果是接口就必須是Interface類型
if(inter.constructor!=Interface){
throw new Error("如果是接口類的話,就必須是Interface類型");
}
//判斷接口中的方法是否全部實現(xiàn)
//遍歷函數(shù)集合
for(var j=0;j<inter.methods.length;j++){
var method=inter.methods[j];//接口中所有函數(shù)
//object[method]傳入的函數(shù)
//最終是判斷傳入的函數(shù)是否與接口中所用函數(shù)匹配
if(!object[method]||typeof object[method]!="function" ){
//實現(xiàn)類中必須有方法名字與接口中所用方法名相同
throw new Error("實現(xiàn)類中沒有完全實現(xiàn)接口中的所有方法")
}
}
}
}
(1)主人類(Person類)
function Person() {
this.name="測試";
this.address="居住在中國";
this.getInfo=function () {
return "名字"+this.name+" 地址"+this.address;
};
this.learn=function () {
alert("學(xué)習(xí)的方法");
}
this.marray=function () {
alert("marray");
}
//驗證接口
Interface.ensureImplement(this,PersonDao);//驗證該類是否全部實現(xiàn)接口中的方法
}
(2)寵物狗(Dog類)
var DogDao=new Interface("DogDao",["getInfo","call","run"]);
var Dog=function () {
this.name="gg";
this.getInfo=function () {
return "狗狗的名字"+this.name;
};
this.call=function () { };
this.run=function () {};
Interface.ensureImplement(this,DogDao);//驗證接口
}
(3)現(xiàn)在可以主人可以給自己的寵物狗辦理寵物領(lǐng)養(yǎng)證件了 -----客戶端代碼
第一種方法:不用門面的方式客戶端的代碼如下
function action(person,dog) {
var r="GG"+new Date().getDay()+Math.floor(Math.random()*11);
var str="辦證成功:編號"+r
+"<br/>主人信息"+person.getInfo()
+"<br>狗狗的信息:"+dog.getInfo();
return str;
}document.write(action(new Person(),new Dog()));
第二種方法:使用門面模式-----將復(fù)雜的事交給門面來做,客戶端壓力可以減小
#1:門面中進行如下的處理
function facade(person,dog) {
var r="GG"+new Date().getDay()+Math.floor(Math.random()*11);
var str="辦證成功:編號"+r
+"<br/>主人信息"+person.getInfo()
+"<br>狗狗的信息:"+dog.getInfo();
this.action=function () {//相當于實例的方法
return str;
};
}
#2:客戶端負責(zé)使用的代碼為
function action2(person,dog) {
document.write(new facade(person,dog).action());
}
action2(new Person(),new Dog());
總結(jié),我們可以看出不適用門面模式的客戶端需要處理較為復(fù)雜的業(yè)務(wù),使用門面后,在門面中處理復(fù)雜的東西,而客戶端只需要簡單的調(diào)用即可。
一個簡單理解門面模式的圖結(jié)構(gòu):

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript模擬php函數(shù)in_array
就是判斷一個元素是否存在于數(shù)組中的函數(shù),既然js里string都有indexOf函數(shù),為什么不在Array對象里設(shè)置一個這樣的函數(shù)呢,其實就用indexOf這個思想挺好的,不知道制定JS標準的人是基于什么考慮,把這樣一個如此常用的功能沒考慮在內(nèi)的。2015-04-04
深入理解JavaScript系列(28):設(shè)計模式之工廠模式詳解
這篇文章主要介紹了深入理解JavaScript系列(28):設(shè)計模式之工廠模式詳解,工廠模式定義一個用于創(chuàng)建對象的接口,這個接口由子類決定實例化哪一個類,需要的朋友可以參考下2015-03-03
JS實現(xiàn)Select的option上下移動的方法
這篇文章主要介紹了JS實現(xiàn)Select的option上下移動的方法,涉及JavaScript動態(tài)操作頁面元素的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2016-03-03
JS實現(xiàn)動畫兼容性的transition和transform實例分析
這篇文章主要介紹了JS實現(xiàn)動畫兼容性的transition和transform方法,結(jié)合實例形式分析了transition和transform方法針對手機端瀏覽器兼容性問題上的相關(guān)處理技巧,需要的朋友可以參考下2016-12-12
JavaScript Date對象詳解及時間戳和時間的相互轉(zhuǎn)換問題
這篇文章主要介紹了JavaScript Date對象詳解及時間戳和時間的相互轉(zhuǎn)換問題,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2024-01-01
JS字符串false轉(zhuǎn)boolean的方法(推薦)
下面小編就為大家?guī)硪黄狫S字符串false轉(zhuǎn)boolean的方法(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-03-03
用js的document.write輸出的廣告無阻塞加載的方法
這篇文章主要介紹了用js的document.write輸出的廣告無阻塞加載的方法,需要的朋友可以參考下2014-06-06

