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

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 世界。

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

做个简单的总结吧

✨ 总结一下

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

📌 你可以用它来:

  • 接老旧系统的接口
  • 封装第三方库的输出
  • 或者在多人协作时保护自己的"数据整洁癖"
相关推荐
CC码码17 分钟前
前端字符串排序搜索可以更加细化了
前端·javascript·面试
喵爱吃鱼18 分钟前
kuma-ui中Flex vs FlexMin的关键区别
前端
codingMan20 分钟前
[Android Compose] 拒绝闪烁!打造丝滑的聊天页面列表(仿微信效果)
前端
你别追我跑不动22 分钟前
基于代码扫描的 Icon 优化实践
前端·性能优化
磊磊磊磊磊23 分钟前
用AI做了个排版工具,分享一下如何高效省钱地用AI!
前端·后端·react.js
喵爱吃鱼24 分钟前
flex 0 flex 1 flex none flex auto 应该在什么场景下使用
前端
雾散声声慢26 分钟前
解决 iOS 上 Swiper 滑动图片闪烁问题:原因分析与最有效的修复方式
前端·css·ios
Crystal32829 分钟前
冒泡排序 bubble sort
前端·javascript·面试
阿蓝灬44 分钟前
clientWidth vs offsetWidth
前端·javascript
一代明君Kevin学长1 小时前
快速自定义一个带进度监控的文件资源类
java·前端·后端·python·文件上传·文件服务·文件流