「软件设计模式杂谈🤔」和后端吵架失败了,于是乎我写了个适配器模式

Hi! 这里是JustHappy ,作为一个前端开发者,更是软件工程师,软件设计模式咱必须要接触吧,所以来吧!一起来聊聊!我们从适配器模式开始吧!

什么玩意儿是"适配器模式"?

我们先来查查百科吧!(以下内容引用自维基百科)

设计模式中,适配器模式 (英语:adapter pattern)有时候也称包装样式或者包装(英语:wrapper)。将一个的接口转接成用户所期待的。一个适配使得因接口不兼容而不能在一起工作的类能在一起工作,做法是将类自己的接口包裹在一个已存在的类中。

主要有两类吧:

  • 🧩 类适配器模式(基于继承)
  • 🧩 对象适配器模式(基于组合)

是不是有些不讲人话,我们来拆解一下吧:

试想一个场景!🤯

又是一个蛋疼的下午,我们要进行前后端联调,出现什么问题呢?后端同学给的接口实在是丑陋,但是咱这"前端切图仔",长期处于鄙视链的底端,愣是没有在 "吵架环节" 说服后端修改接口,怎么办呢?那我们自己来把这个接口变得不那么丑陋吧

: 这里后端提供的接口不符合我们的预期,所以我们要处理....

怎么办呢?

假设后端传递过来的接口长下面这样

js 复制代码
{
  "user_name": "Simon",
  "user_age": 25,
  "user_status": 1
}

可是你页面中已经写好了对应的逻辑,需要的数据结构应该是下面这样,尴尬了,字段名也不对,类型还对不上。

js 复制代码
IUser = {
  name: string
  age: number
  isActive: boolean
}

怎么办?总有一个人需要做出让步吧...... 既然我们吵架吵输了

那就使用适配器模式吧!

话不多说,我们在这实现一个最简单的适配器

js 复制代码
// 后端返回的数据
const backendData = {
  user_name: "Simon",
  user_age: 25,
  user_status: 1
}

// 我们期望使用的数据结构是这样子的:
/*
{
  name: "Simon",
  age: 25,
  isActive: true
}
*/

// 适配器函数:把后端数据"翻译"成我们喜欢的格式
function adaptUser(data) {
  return {
    name: data.user_name,
    age: data.user_age,
    isActive: data.user_status === 1
  }
}

// 使用适配器
const user = adaptUser(backendData)

console.log(user)
// 输出:{ name: "Simon", age: 25, isActive: true }

🧬 类适配器 vs 对象适配器:到底差在哪?

简单点讲:

  • 类适配器 通过继承实现,适合在强类型语言里搞搞(比如 Java、C#)。
  • 对象适配器 用的是组合(组合优于继承听说过吧~),更适合咱 JS/TS 世界。

所以我们前端用得最多的,其实就是对象适配器了。写个函数转换一下,就能干翻一堆奇怪数据结构。

做个简单的总结吧

✨ 总结一下

适配器模式就像我们生活中的万能插头,左手接老式接口,右手接新式需求,居中搞桥梁。在实际项目中,特别是做前后端联调时,简直不要太常见!

📌 你可以用它来:

  • 接老旧系统的接口
  • 封装第三方库的输出
  • 或者在多人协作时保护自己的"数据整洁癖"
相关推荐
rgeshfgreh1 分钟前
Spring事务传播机制深度解析
java·前端·数据库
Hilaku39 分钟前
我用 Gemini 3 Pro 手搓了一个并发邮件群发神器(附源码)
前端·javascript·github
IT_陈寒40 分钟前
Java性能调优实战:5个被低估却提升30%效率的JVM参数
前端·人工智能·后端
快手技术41 分钟前
AAAI 2026|全面发力!快手斩获 3 篇 Oral,12 篇论文入选!
前端·后端·算法
颜酱42 分钟前
前端算法必备:滑动窗口从入门到很熟练(最长/最短/计数三大类型)
前端·后端·算法
全栈前端老曹1 小时前
【包管理】npm init 项目名后底层发生了什么的完整逻辑
前端·javascript·npm·node.js·json·包管理·底层原理
YUEchn1 小时前
无处不在的Agent
设计模式·llm·agent
HHHHHY1 小时前
mathjs简单实现一个数学计算公式及校验组件
前端·javascript·vue.js
boooooooom1 小时前
Vue3 provide/inject 跨层级通信:最佳实践与避坑指南
前端·vue.js
一颗烂土豆1 小时前
Vue 3 + Three.js 打造轻量级 3D 图表库 —— chart3
前端·vue.js·数据可视化