JavaScript適配器模式詳解
適配模式可用來在現(xiàn)有接口和不兼容的類之間進(jìn)行適配,使用這種模式的對(duì)象又叫包裝器(wrapper),因?yàn)樗鼈兪窃谟靡粋€(gè)新的接口包裝另一個(gè)對(duì)象。
基本理論
適配器模式:將一個(gè)接口轉(zhuǎn)換成客戶端需要的接口而不需要去修改客戶端代碼,使得不兼容的代碼可以一起工作。
適配器主要有3個(gè)角色組成:
(1)客戶端:調(diào)用接口的類
(2)適配器:用來連接客戶端接口和提供服務(wù)的接口的類
(3)適配者:提供服務(wù),但是卻與客戶端接口需求不兼容服務(wù)類。
此處 有一個(gè)實(shí)例是關(guān)于兩個(gè)數(shù)的加法的。
一、先有一個(gè)能夠?qū)崿F(xiàn),兩個(gè)數(shù)加法的服務(wù)和客戶端。
(1)先引入接口檢驗(yàn)類----檢查實(shí)現(xiàn)該接口的類是否實(shí)現(xiàn)了接口中所用方法。
//(定義一個(gè)靜態(tài)方法來實(shí)現(xiàn)接口與實(shí)現(xiàn)類的直接檢驗(yàn) //靜態(tài)方法不要寫出Interface.prototype ,因?yàn)檫@是寫到接口的原型鏈上的 //我們要把靜態(tài)的函數(shù)直接寫到類層次上 //定義一個(gè)接口類 var Interface=function (name,methods) {//name:接口名字 if(arguments.length<2){ alert("必須是兩個(gè)參數(shù)") } this.name=name; this.methods=[];//定義一個(gè)空數(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個(gè)") return false; } for(var i=1;i<arguments.length;i++){ var inter=arguments[i]; //如果是接口就必須是Interface類型 if(inter.constructor!=Interface){ throw new Error("如果是接口類的話,就必須是Interface類型"); } //判斷接口中的方法是否全部實(shí)現(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" ){//實(shí)現(xiàn)類中必須有方法名字與接口中所用方法名相同 throw new Error("實(shí)現(xiàn)類中沒有完全實(shí)現(xiàn)接口中的所有方法") } } } }
(2)使用接口類同一接口
var InterfaceResult=new Interface("InterfaceResult",["add"]);
(3)服務(wù)端兩個(gè)數(shù)的加法
function First() { this.add=function (x,y) { return x+y; } Interface.ensureImplement(this,InterfaceResult);//接口檢驗(yàn) }
(4)客戶端調(diào)用服務(wù)端代碼
var first=new First(); alert(first.add(1,2)) ;//3
二、現(xiàn)在有一個(gè)要求就是,需要換一個(gè)類庫,但是客戶端的程序不希望有大的改動(dòng)。
(1)依然繼承相同接口的基礎(chǔ)上,類庫為
function Second() { this.add=function (numberList) { //[1,2,3] "1+2+3" eval("1+2+3") return eval(numberList.join("+")); } Interface.ensureImplement(this,InterfaceResult);//檢驗(yàn)當(dāng)前類是否完全實(shí)現(xiàn)接口中的方法 }
此時(shí)我們?nèi)绻枰褂迷擃悗斓脑?,客戶端又不能該,那么用和之前的調(diào)用方式:
var second=new Second(); alert(second.add(1,3));//已經(jīng)不能這樣使用了
是完全不符合客戶端的要求的。為了在保證客戶端不變的情況下,又能使用新的類庫,我們需要使用適配器模式?,F(xiàn)在接口發(fā)生了變化,使用適配器兼容,以便適應(yīng)客戶端的不變。
使客戶端與新的接口相會(huì)兼容。
(2)適配器
function ThirdWarpper() { this.add=function (x,y) { var arr=new Array(); arr.push(x); arr.push(y); return new Second().add(arr); } Interface.ensureImplement(this,InterfaceResult); }
(3)客戶端代碼
//客戶端 var third=new ThirdWarpper(); var result= third.add(1,8);//傳遞數(shù) alert(result);
針對(duì)上述的使用新的類庫后的圖解為:
總結(jié)
從表面上看,適配器模式很像外觀模式。它們都要對(duì)別的對(duì)象進(jìn)行包裝并改變其呈現(xiàn)的接口。二者的差別在于它們?nèi)绾胃淖兘涌?。外觀元素展現(xiàn)的是一個(gè)簡化的接口,它并不提供額外的選擇,而且有時(shí)為了方便完成常見任務(wù)它還會(huì)做出一些假定。而適配器則要把一個(gè)接口轉(zhuǎn)換為另一個(gè)接口,它并不會(huì)濾除某些能力,也不會(huì)簡化接口。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- javascript設(shè)計(jì)模式之Adapter模式【適配器模式】實(shí)現(xiàn)方法示例
- JavaScript設(shè)計(jì)模式之適配器模式介紹
- 深入理解JavaScript系列(39):設(shè)計(jì)模式之適配器模式詳解
- 詳解JavaScript實(shí)現(xiàn)設(shè)計(jì)模式中的適配器模式的方法
- javascript設(shè)計(jì)模式 – 適配器模式原理與應(yīng)用實(shí)例分析
- JavaScript設(shè)計(jì)模式學(xué)習(xí)之適配器模式
- JavaScript 設(shè)計(jì)模式之組合模式解析
- JavaScript組合模式學(xué)習(xí)要點(diǎn)
- 設(shè)計(jì)模式中的組合模式在JavaScript程序構(gòu)建中的使用
- javascript設(shè)計(jì)模式 – 組合模式原理與應(yīng)用實(shí)例分析
- JavaScript設(shè)計(jì)模式開發(fā)中組合模式的使用教程
- javascript適配器模式和組合模式原理與實(shí)現(xiàn)方法詳解
相關(guān)文章
js腳本實(shí)現(xiàn)數(shù)據(jù)去重
最近在一個(gè)項(xiàng)目中,需要去除掉重復(fù)的數(shù)據(jù),之前都是在后臺(tái)實(shí)現(xiàn),現(xiàn)在客戶需求是在前臺(tái)去重,于是就想到了javascript腳本。2014-11-11再談JavaScript中bind、call、apply三個(gè)方法的區(qū)別與使用方式
這篇文章主要介紹了Javascript中bind、call、apply三個(gè)方法的使用方式,需要的朋友可以參考下2022-05-05JS應(yīng)用正則表達(dá)式轉(zhuǎn)換大小寫示例
這篇文章主要介紹了JS應(yīng)用正則表達(dá)式轉(zhuǎn)換大小寫,以首字母大寫,其它字母小寫為例,喜歡的朋友可以參考下2014-09-09怎么理解wx.navigateTo的events參數(shù)使用詳情
這篇文章主要介紹了怎么理解wx.navigateTo的events參數(shù)使用詳情,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05JavaScript中你不知道的數(shù)學(xué)方法分享(非常實(shí)用)
JavaScript的Math對(duì)象包含了一些非常有用和強(qiáng)大的數(shù)學(xué)操作,可以在Web開發(fā)中使用,本文為大家整理了一些非常實(shí)用的數(shù)學(xué)方法,希望對(duì)大家有所幫助2023-07-07如何讓你的JavaScript函數(shù)更加優(yōu)雅詳解
在Js世界中有些操作會(huì)讓你無法理解,但是卻無比優(yōu)雅,下面這篇文章主要給大家介紹了關(guān)于如何讓你的JavaScript函數(shù)更加優(yōu)雅的相關(guān)資料,需要的朋友可以參考下2021-07-07js中setTimeout的妙用--防止循環(huán)超時(shí)
本文主要介紹了使用setTimeout實(shí)現(xiàn)防止循環(huán)超時(shí)的方法,具有很好的參考價(jià)值。下面跟著小編一起來看下吧2017-03-03js之點(diǎn)擊 超連接,提示一個(gè)層.點(diǎn)擊空白層消失
最近寫一個(gè)功能,需要用到點(diǎn)擊空白層就讓指定的一個(gè)層消失,這里簡單介紹下實(shí)現(xiàn)方法,需要的朋友可以參考下2007-05-05