1. 程式人生 > 程式設計 >JavaScript介面卡模式原理與用法例項詳解

JavaScript介面卡模式原理與用法例項詳解

本文例項講述了JavaScript介面卡模式原理與用法。分享給大家供大家參考,具體如下:

適配模式可用來在現有介面和不相容的類之間進行適配,使用這種模式的物件又叫包裝器(wrapper),因為它們是在用一個新的介面包裝另一個物件。

基本理論

介面卡模式:將一個介面轉換成客戶端需要的介面而不需要去修改客戶端程式碼,使得不相容的程式碼可以一起工作。

介面卡主要有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));//已經不能這樣使用了

是完全不符合客戶端的要求的。為了在保證客戶端不變的情況下,又能使用新的類庫,我們需要使用介面卡模式。現在介面發生了變化,使用介面卡相容,以便適應客戶端的不變

使客戶端與新的介面相會相容。

(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介面卡模式原理與用法例項詳解

總結,

從表面上看,介面卡模式很像外觀模式。它們都要對別的物件進行包裝並改變其呈現的介面。二者的差別在於它們如何改變介面。外觀元素展現的是一個簡化的介面,它並不提供額外的選擇,
而且有時為了方便完成常見任務它還會做出一些假定。而介面卡則要把一個介面轉換為另一個介面,它並不會濾除某些能力,也不會簡化介面。

感興趣的朋友可以使用線上HTML/CSS/JavaScript前端程式碼除錯執行工具:http://tools.jb51.net/code/WebCodeRun測試上述程式碼執行效果。

更多關於JavaScript相關內容還可檢視本站專題:《javascript面向物件入門教程》、《JavaScript錯誤與除錯技巧總結》、《JavaScript資料結構與演算法技巧總結》、《JavaScript遍歷演算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程式設計有所幫助。