這篇文章將為大家詳細講解有關JavaScript門面模式的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務領域包括:成都網(wǎng)站建設、成都網(wǎng)站設計、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務,滿足客戶于互聯(lián)網(wǎng)時代的南昌縣網(wǎng)站設計、移動媒體設計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡建設合作伙伴!
外部與一個子系統(tǒng)的通信必須通過一個系統(tǒng)的一個門面對象進行,這就是門面模式。
門面模式具備如下兩個角色:
1. 門面角色
客戶端可以調(diào)用這個角色方法,此角色中有子系統(tǒng)的應用(知曉相關的(一個或多個)子系統(tǒng)的功能和責任)。本角色會將所有從客戶端發(fā)來的請求委派到相應的子系統(tǒng)去。
2. 子系統(tǒng)角色
可以同時有一個或多個子系統(tǒng)。每一個子系統(tǒng)都不是一個單獨的類,而是一些類的集合。每一個子系統(tǒng)都可以被客戶端直接調(diào)用(這樣客戶端代碼會多),或被門面角色調(diào)用。子系統(tǒng)并不知道門面的存在,對于子系統(tǒng)而言,門面僅僅是另一個客戶端而已。
下面我們來看一個可以提現(xiàn)門面模式的簡單需求:主人為自己的寵物狗辦理的相應的寵物領養(yǎng)證件
從這個簡單的需求中我們可以大致分析出我們需要:主人Person類和寵物狗Dog類 的一些相關信息
在下面的例子中國會涉及到接口的驗證,現(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("學習的方法"); } 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)在可以主人可以給自己的寵物狗辦理寵物領養(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()));
第二種方法:使用門面模式-----將復雜的事交給門面來做,客戶端壓力可以減小
#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:客戶端負責使用的代碼為
function action2(person,dog) { document.write(new facade(person,dog).action()); } action2(new Person(),new Dog());
總結,我們可以看出不適用門面模式的客戶端需要處理較為復雜的業(yè)務,使用門面后,在門面中處理復雜的東西,而客戶端只需要簡單的調(diào)用即可。
一個簡單理解門面模式的圖結構:
關于“JavaScript門面模式的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
本文題目:JavaScript門面模式的示例分析
網(wǎng)頁地址:http://jinyejixie.com/article8/jjhcip.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供服務器托管、手機網(wǎng)站建設、面包屑導航、網(wǎng)站營銷、網(wǎng)站設計公司、外貿(mào)網(wǎng)站建設
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)