溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在JavaScript中使用適配器模式

發布時間:2021-03-31 17:05:00 來源:億速云 閱讀:153 作者:Leah 欄目:web開發

本篇文章給大家分享的是有關如何在JavaScript中使用適配器模式,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

基本理論

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

適配器主要有3個角色組成:

(1)客戶端:調用接口的類
(2)適配器:用來連接客戶端接口和提供服務的接口的類
(3)適配者:提供服務,但是卻與客戶端接口需求不兼容服務類。

此處 有一個實例是關于兩個數的加法的。

一,先有一個能夠實現,兩個數加法的服務和客戶端。

(1)先引入接口檢驗類----檢查實現該接口的類是否實現了接口中所用方法。

//(定義一個靜態方法來實現接口與實現類的直接檢驗
//靜態方法不要寫出Interface.prototype ,因為這是寫到接口的原型鏈上的
//我們要把靜態的函數直接寫到類層次上
//定義一個接口類
var Interface=function (name,methods) {//name:接口名字
  if(arguments.length<2){
    alert("必須是兩個參數")
  }
  this.name=name;
  this.methods=[];//定義一個空數組裝載函數名
  for(var i=0;i<methods.length;i++){
    if(typeof methods[i]!="string"){
      alert("函數名必須是字符串類型");
    }else {
      this.methods.push( methods[i]);
    }
  }
};
Interface.ensureImplement=function (object) {
  if(arguments.length<2){
    throw new Error("參數必須不少于2個")
    return false;
  }
  for(var i=1;i<arguments.length;i++){
    var inter=arguments[i];
    //如果是接口就必須是Interface類型
    if(inter.constructor!=Interface){
      throw new Error("如果是接口類的話,就必須是Interface類型");
    }
    //判斷接口中的方法是否全部實現
    //遍歷函數集合
    for(var j=0;j<inter.methods.length;j++){
      var method=inter.methods[j];//接口中所有函數

      //object[method]傳入的函數
      //最終是判斷傳入的函數是否與接口中所用函數匹配
      if(!object[method]||typeof object[method]!="function" ){//實現類中必須有方法名字與接口中所用方法名相同
        throw new Error("實現類中沒有完全實現接口中的所有方法")
      }
    }
  }
}

(2)使用接口類同一接口

 var InterfaceResult=new Interface("InterfaceResult",["add"]);

(3)服務端兩個數的加法

function First() {
    this.add=function (x,y) {
     return x+y;
    }
    Interface.ensureImplement(this,InterfaceResult);//接口檢驗
  }

(4)客戶端調用服務端代碼

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

二,現在有一個要求就是,需要換一個類庫,但是客戶端的程序不希望有大的改動。

(1)依然繼承相同接口的基礎上,類庫為

function Second() {
    this.add=function (numberList) {
      //[1,2,3] "1+2+3" eval("1+2+3")
      return eval(numberList.join("+"));
    }
    Interface.ensureImplement(this,InterfaceResult);//檢驗當前類是否完全實現接口中的方法
  }

此時我們如果需要使用該類庫的話,客戶端又不能該,那么用和之前的調用方式:

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

是完全不符合客戶端的要求的。為了在保證客戶端不變的情況下,又能使用新的類庫,我們需要使用適配器模式?,F在接口發生了變化,使用適配器兼容,以便適應客戶端的不變

使客戶端與新的接口相會兼容。

(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);//傳遞數
   alert(result);

針對上述的使用新的類庫后的圖解為:

 如何在JavaScript中使用適配器模式

以上就是如何在JavaScript中使用適配器模式,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女