ES6 實現之適配器模式 Adapter

概述

適配器模式的做用是解決兩個對象間的接口不兼容的問題。使用適配器模式以後,本來因爲接口不兼容而不能工做的兩個對象能夠一塊兒工做。設計模式

舉個生活中的例子:港式插頭轉換器,港式的電器插頭比大陸的電器插頭體積要大一些。若是從香港買了一個 Mac book,咱們會發現充電器沒法插在家裏的插座上,爲此而改造家裏的插座顯然不方便,因此咱們須要一個轉換插頭。函數

運用

經過上述例子,咱們能夠知道適配器模式有三個角色:測試

  • 目標角色(Target):大陸的電器插頭
  • 源角色(Adaptee): 港式的電器插頭
  • 適配器角色(Adapter): 把港式的電器插頭轉成更小大陸的電器插頭,來適配大陸插座
目標角色實現
class Target {
    small(){
        throw new Error('This method must be overwritten!');
    }
}
複製代碼

由Target接口實現目標角色,用戶期待更小的電器插頭。ui

源角色實現
class Adaptee {
    big(){
        console.log("港式的電器插頭可用咯~~");
    }
}
複製代碼

Adaptee 屬於更大的港式的電器插頭,這和用戶所指望的不一樣。因此這裏須要引入適配器,去轉換成用戶所期待的目標接口。this

適配器實現
class Adapter extends Target {
    constructor(adaptee) {
        super();
        this.adaptee = adaptee;
    }
    small() {
        this.adaptee.big();
    }
}
複製代碼

Adapter 類繼承了 Target,重寫 small 函數,最後經過適配器,把港式big轉成了大陸的small了。spa

測試一下
let adaptee=new Adaptee();
let adapter=new Adapter(adaptee);
adapter.small();
# 港式的電器插頭可用咯~~
複製代碼

【第一次打廣告:全部設計模式,請看 ES6 實現最實用的 22 種設計模式

相關文章
相關標籤/搜索