一天一个设计模式---适配器模式

概念

适配器模式是一种结构型设计模式,用于将一个类的接口转换成客户端所期望的另一个接口。它允许不兼容的接口之间进行协同工作,使得原本由于接口不匹配而无法合作的类能够一起工作。

具体内容

适配器模式主要包括以下几个要素:

  1. 目标接口(Target Interface): 客户端期望的接口,适配器模式的目标是使被适配者(Adaptee)的接口能够符合目标接口。
  2. 适配器(Adapter): 实现目标接口,并包含一个对被适配者的引用。适配器负责将被适配者的接口转换成目标接口,从而使得客户端可以与被适配者协同工作。
  3. 被适配者(Adaptee): 需要被适配的接口。被适配者是原本无法与目标接口直接协同工作的类。

类结构图

适用场景

  • 现有系统与新系统的集成: 当引入新组件或系统时,为了与现有系统协同工作,可以使用适配器模式来统一接口。
  • 第三方库的使用: 当使用第三方库或组件时,其接口可能不符合当前系统的需求,通过适配器可以使其与系统其他部分协同工作。
  • 接口版本升级: 当接口发生变化,为了保持向后兼容性,可以使用适配器模式适配新旧接口之间的差异。

实现

JS 复制代码
// 目标接口
// 目标接口
class Target {
  request() {
    console.log("Target's request");
  }
}

// 被适配者
class Adaptee {
  specificRequest() {
    console.log("Adaptee's specific request");
  }
}

// 适配器
class Adapter extends Target {
  constructor(adaptee) {
    super();
    this.adaptee = adaptee;
  }

  request() {
    this.adaptee.specificRequest();
  }
}

// 客户端代码
const adaptee = new Adaptee();
const adapter = new Adapter(adaptee);

adapter.request(); // 调用适配器的request,实际上执行了被适配者的specificRequest
相关推荐
zz58833 分钟前
面试官问"JS的类型"时,到底想听到什么?
javascript
gjwjuejin35 分钟前
全埋点技术方案深度剖析:从事件代理到无痕采集的完整实现
javascript
前端若水2 小时前
在 Vue 2 与 Vue 3 中使用 markdown-it-vue 渲染 Markdown 和数学公式
前端·javascript·vue.js
之歆2 小时前
DAY_10 JavaScript 深度解析:原型链 · 引用类型 · 内置对象 · 数组方法全攻略(下)
开发语言·前端·javascript·ecmascript
__log2 小时前
ComfyUI 集成技术方案分析报告
javascript·python·django
ZC跨境爬虫2 小时前
跟着 MDN 学 HTML day_56:(HTML 表格基础完全指南)
前端·javascript·ui·html·音视频
江晓曼*凡云基地3 小时前
Hermes Agent 多Agent模式:并行拆解复杂任务的实战指南
javascript·windows·microsoft
小白学大数据3 小时前
Python 爬虫动态 JS 渲染与无头浏览器实战选型指南
开发语言·javascript·爬虫·python
飘尘3 小时前
WebAssembly 是什么?它为什么重要?
前端·javascript
之歆3 小时前
DAY_10 JavaScript 深度解析:原型链 · 引用类型 · 内置对象 · 数组方法全攻略(上)
开发语言·javascript·ecmascript