欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript適配器模式原理與用法實(shí)例詳解

 更新時(shí)間:2020年03月09日 12:14:52   作者:WFaceBoss  
這篇文章主要介紹了JavaScript適配器模式原理與用法,結(jié)合具體實(shí)例形式詳細(xì)分析了JavaScript適配器模式概念、原理、使用方法與操作注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了JavaScript適配器模式原理與用法。分享給大家供大家參考,具體如下:

適配模式可用來(lái)在現(xiàn)有接口和不兼容的類(lèi)之間進(jìn)行適配,使用這種模式的對(duì)象又叫包裝器(wrapper),因?yàn)樗鼈兪窃谟靡粋€(gè)新的接口包裝另一個(gè)對(duì)象。

基本理論

適配器模式:將一個(gè)接口轉(zhuǎn)換成客戶(hù)端需要的接口而不需要去修改客戶(hù)端代碼,使得不兼容的代碼可以一起工作。

適配器主要有3個(gè)角色組成:

(1)客戶(hù)端:調(diào)用接口的類(lèi)
(2)適配器:用來(lái)連接客戶(hù)端接口和提供服務(wù)的接口的類(lèi)
(3)適配者:提供服務(wù),但是卻與客戶(hù)端接口需求不兼容服務(wù)類(lèi)。

此處 有一個(gè)實(shí)例是關(guān)于兩個(gè)數(shù)的加法的。

一,先有一個(gè)能夠?qū)崿F(xiàn),兩個(gè)數(shù)加法的服務(wù)和客戶(hù)端。

(1)先引入接口檢驗(yàn)類(lèi)----檢查實(shí)現(xiàn)該接口的類(lèi)是否實(shí)現(xiàn)了接口中所用方法。

//(定義一個(gè)靜態(tài)方法來(lái)實(shí)現(xiàn)接口與實(shí)現(xiàn)類(lèi)的直接檢驗(yàn)
//靜態(tài)方法不要寫(xiě)出Interface.prototype ,因?yàn)檫@是寫(xiě)到接口的原型鏈上的
//我們要把靜態(tài)的函數(shù)直接寫(xiě)到類(lèi)層次上
//定義一個(gè)接口類(lèi)
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ù)名必須是字符串類(lèi)型");
    }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類(lèi)型
    if(inter.constructor!=Interface){
      throw new Error("如果是接口類(lèi)的話(huà),就必須是Interface類(lèi)型");
    }
    //判斷接口中的方法是否全部實(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)類(lèi)中必須有方法名字與接口中所用方法名相同
        throw new Error("實(shí)現(xiàn)類(lèi)中沒(méi)有完全實(shí)現(xiàn)接口中的所有方法")
      }
    }
  }
}

(2)使用接口類(lèi)同一接口

 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)客戶(hù)端調(diào)用服務(wù)端代碼

var first=new First();
alert(first.add(1,2)) ;//3

二,現(xiàn)在有一個(gè)要求就是,需要換一個(gè)類(lèi)庫(kù),但是客戶(hù)端的程序不希望有大的改動(dòng)。

(1)依然繼承相同接口的基礎(chǔ)上,類(lèi)庫(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)前類(lèi)是否完全實(shí)現(xiàn)接口中的方法
  }

此時(shí)我們?nèi)绻枰褂迷擃?lèi)庫(kù)的話(huà),客戶(hù)端又不能該,那么用和之前的調(diào)用方式:

var second=new Second();
alert(second.add(1,3));//已經(jīng)不能這樣使用了

是完全不符合客戶(hù)端的要求的。為了在保證客戶(hù)端不變的情況下,又能使用新的類(lèi)庫(kù),我們需要使用適配器模式?,F(xiàn)在接口發(fā)生了變化,使用適配器兼容,以便適應(yīng)客戶(hù)端的不變

使客戶(hù)端與新的接口相會(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)客戶(hù)端代碼

  //客戶(hù)端
  var third=new ThirdWarpper();
   var result= third.add(1,8);//傳遞數(shù)
   alert(result);

針對(duì)上述的使用新的類(lèi)庫(kù)后的圖解為:

 

總結(jié),

從表面上看,適配器模式很像外觀模式。它們都要對(duì)別的對(duì)象進(jìn)行包裝并改變其呈現(xiàn)的接口。二者的差別在于它們?nèi)绾胃淖兘涌凇M庥^元素展現(xiàn)的是一個(gè)簡(jiǎn)化的接口,它并不提供額外的選擇,
而且有時(shí)為了方便完成常見(jiàn)任務(wù)它還會(huì)做出一些假定。而適配器則要把一個(gè)接口轉(zhuǎn)換為另一個(gè)接口,它并不會(huì)濾除某些能力,也不會(huì)簡(jiǎn)化接口。

感興趣的朋友可以使用在線(xiàn)HTML/CSS/JavaScript前端代碼調(diào)試運(yùn)行工具http://tools.jb51.net/code/WebCodeRun測(cè)試上述代碼運(yùn)行效果。

更多關(guān)于JavaScript相關(guān)內(nèi)容還可查看本站專(zhuān)題:《javascript面向?qū)ο笕腴T(mén)教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論