设计模式-适配器模式

简介

  • 适配器模式 (Adapter Pattern)是一种结构型设计模式,它允许不兼容的接口能够一起工作。这种模式通常用于使现有的类与其他类一起工作,而无需修改它们的源代码。在 JavaScript 中,适配器模式可以用来确保不同的类或对象之间能够通过一个统一的接口进行交互

概念

  • 设想你有两个组件或类,它们执行相似的功能但是接口不兼容。例如,一个组件可能使用 fetchData 方法,而另一个组件使用 getData 方法。如果你想在不修改这两个已存在的组件的情况下使它们能够互操作,你可以使用适配器模式。

    适配器模式主要涉及三个角色:

    • 目标接口(Target):客户期望使用的接口。它定义了客户希望如何调用某个功能。
    • 待适配的类(Adaptee):需要被适配的类,它有自己的接口和实现,但不符合目标接口。
    • 适配器(Adapter):实现或继承目标接口,并将目标接口的调用转到待适配的类的实现上。

示例

  • 假设你正在使用一个第三方库,它提供了一个 OldCalculator 类,具有一个 performOperation 方法。现在,你的应用使用了一个新的接口 NewCalculator,这个新接口期望调用的方法名为 calculateOldCalculator 不能直接用于新的应用,因为接口不匹配。

    OldCalculator 类(Adaptee):

    javascript 复制代码
    class OldCalculator {
      performOperation(x, y, operation) {
        switch (operation) {
          case 'add':
            return x + y;
          case 'sub':
            return x - y;
          default:
            return NaN;
        }
      }
    }

    NewCalculator 接口(Target):

    javascript 复制代码
    class NewCalculator {
      calculate() {
        throw new Error('This method should be implemented');
      }
    }

    适配器(Adapter):

    javascript 复制代码
    class CalculatorAdapter extends NewCalculator {
      constructor() {
        super();
        this.oldCalc = new OldCalculator();
      }
    
      calculate(x, y, operation) {
        return this.oldCalc.performOperation(x, y, operation);
      }
    }

    使用适配器

    javascript 复制代码
    // 创建适配器实例
    const adapter = new CalculatorAdapter();
    
    // 现在可以使用新接口调用旧组件的功能
    console.log(adapter.calculate(5, 3, 'add'));  // 输出: 8
    console.log(adapter.calculate(5, 3, 'sub'));  // 输出: 2

总结

  • 适配器模式使得你能够将不兼容的接口桥接到一起工作,而无需改动现有的代码。这提供了很大的灵活性和更简洁的集成方式。在 JavaScript 中,适配器通常是通过创建新的类(适配器),继承或组合目标类或接口,并在内部调用待适配类的方法来实现的。这样,适配器在外部表现为目标接口,而内部利用已存在的实现。这种模式在处理多个库和服务,尤其是在它们期望的接口不一致时,非常有用。
相关推荐
数据智能老司机1 天前
精通 Python 设计模式——创建型设计模式
python·设计模式·架构
数据智能老司机1 天前
精通 Python 设计模式——SOLID 原则
python·设计模式·架构
烛阴1 天前
【TS 设计模式完全指南】懒加载、缓存与权限控制:代理模式在 TypeScript 中的三大妙用
javascript·设计模式·typescript
李广坤1 天前
工厂模式
设计模式
幂简集成explinks2 天前
e签宝签署API更新实战:新增 signType 与 FDA 合规参数配置
后端·设计模式·开源
大飞pkz2 天前
【设计模式】C#反射实现抽象工厂模式
设计模式·c#·抽象工厂模式·c#反射·c#反射实现抽象工厂模式
努力也学不会java2 天前
【设计模式】抽象工厂模式
java·设计模式·oracle·抽象工厂模式
青草地溪水旁2 天前
设计模式(C++)详解—抽象工厂模式 (Abstract Factory)(2)
c++·设计模式·抽象工厂模式
青草地溪水旁2 天前
设计模式(C++)详解—抽象工厂模式 (Abstract Factory)(1)
c++·设计模式·抽象工厂模式
Magnetic_h3 天前
【iOS】设计模式复习
笔记·学习·ios·设计模式·objective-c·cocoa