適配模式可用來在現(xiàn)有接口和不兼容的類之間進(jìn)行適配,使用這種模式的對(duì)象又叫包裝器(wrapper),因?yàn)樗鼈兪窃谟靡粋€(gè)新的接口包裝另一個(gè)對(duì)象。
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對(duì)這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡(jiǎn)單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:國(guó)際域名空間、虛擬空間、營(yíng)銷軟件、網(wǎng)站建設(shè)、東安網(wǎng)站維護(hù)、網(wǎng)站推廣。
基本理論
適配器模式:將一個(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è)類庫(kù),但是客戶端的程序不希望有大的改動(dòng)。
(1)依然繼承相同接口的基礎(chǔ)上,類庫(kù)為
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)绻枰褂迷擃悗?kù)的話,客戶端又不能該,那么用和之前的調(diào)用方式:
var second=new Second(); alert(second.add(1,3));//已經(jīng)不能這樣使用了
是完全不符合客戶端的要求的。為了在保證客戶端不變的情況下,又能使用新的類庫(kù),我們需要使用適配器模式。現(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ì)上述的使用新的類庫(kù)后的圖解為:

總結(jié)
從表面上看,適配器模式很像外觀模式。它們都要對(duì)別的對(duì)象進(jìn)行包裝并改變其呈現(xiàn)的接口。二者的差別在于它們?nèi)绾胃淖兘涌凇M庥^元素展現(xiàn)的是一個(gè)簡(jiǎn)化的接口,它并不提供額外的選擇,而且有時(shí)為了方便完成常見任務(wù)它還會(huì)做出一些假定。而適配器則要把一個(gè)接口轉(zhuǎn)換為另一個(gè)接口,它并不會(huì)濾除某些能力,也不會(huì)簡(jiǎn)化接口。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
新聞標(biāo)題:JavaScript適配器模式詳解
鏈接URL:http://chinadenli.net/article24/gsgije.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)、ChatGPT、網(wǎng)站內(nèi)鏈、移動(dòng)網(wǎng)站建設(shè)、Google、網(wǎng)站設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)