国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JavaScript設計模式之適配器模式介紹

2019-11-20 13:35:09
字體:
來源:轉載
供稿:網友

適配器模式說明

說明: 適配器模式,一般是為要使用的接口,不符本應用或本系統使用,而需引入的中間適配層類或對象的情況;

場景: 就好比我們買了臺手機,買回來后發現,充電線插頭是三插頭,但家里,只有兩插頭的口的插座,怎么辦?為了方便,也有為能在任何地方都能充上電,就得去買個通用充電適配器; 這樣手機才能在自己家里充上電;不然只能放著,或跑到有這個插頭的地方充電;

實際開發環境下,由于舊的系統,或第三方應用提供的接口,與我們定義的接口不匹配,在以面向接口編程的環境下,就無法使用這樣舊的,或第三方的接口,這時我們就使用適配類繼承待適匹配的類,并讓適配類實現接口的方式來引入舊的系統或第三方應用的接口;

這樣使用接口編程時,就可以使用這個適匹配類,來間接調用舊的系統或第三方應用的接口。

在 Javascript 要實現類似動態面向對象語言的適配器模式的代碼,可以使用到 prototype 的繼承實例來實現;因為是基于接口約束的,但是Javascript沒有接口這號東西,我們去掉接口這一層,直接實現接口實現類 Target ,模擬類似的源碼出來;

源碼實例

1. 待適配的類及接口方法:


復制代碼 代碼如下:

function Adaptee() {
    this.name = 'Adaptee';
}
Adaptee.prototype.getName = function() {
    return this.name;
}

2. 普通實現類 [由于 Javascript 中沒有接口,所以就直接提供實現類]

復制代碼 代碼如下:

function Target() {
    this.name = 'Target';
}

Target.prototype.queryName= function() {
    return this.name;
}

3. 適配類:


復制代碼 代碼如下:

function Adapte() {
    this.name = '';
}

Adapte.prototype = new Adaptee();

Adapte.prototype.queryName = function() {
    this.getName();
}

4.使用方法:


復制代碼 代碼如下:

var local = new Target();
local.queryName(); //調用普通實現類

var adapte = new Adapte();
adapte.queryName(); //調用舊的系統或第三方應用接口;

其他說明

上面第四步,var local 以及 var adapte 類似像 Java,C# 這樣的面向對象語言中接口引用指定,如:


復制代碼 代碼如下:

interface Target {
    public String queryName();
}
//接口引用指向
Target local = new RealTarget(); //即上面 Javascript 的 Target 實現類
local.queryName();

//適配器
Target adapte = new Adapte();
adapte.queryName();

可見適配器類是連接接口與目標類接口的中間層;就是用來解決,需要的目標已經存在了,但我們無法直接使用,不能跟我們的代碼定義協同使用,就得使用適器模式,適配器模式也叫轉換模式,包裝模式;

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 黄石市| 辽宁省| 丰顺县| 廊坊市| 鸡泽县| 阳江市| 根河市| 上杭县| 昂仁县| 普洱| 武平县| 南京市| 芮城县| 萨迦县| 玛沁县| 水富县| 武胜县| 绥芬河市| 漠河县| 松潘县| 英吉沙县| 且末县| 明光市| 普宁市| 尼玛县| 星座| 门头沟区| 通化市| 浙江省| 岱山县| 青田县| 东光县| 琼海市| 海阳市| 蚌埠市| 恩平市| 房产| 图木舒克市| 天津市| 沙河市| 定结县|