news 2026/4/23 10:27:44

【API 设计之道】04 字段掩码模式:让前端决定后端返回什么

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【API 设计之道】04 字段掩码模式:让前端决定后端返回什么

大家好,我是Tony Bai。

欢迎来到我们的专栏 《API 设计之道:从设计模式到 Gin 工程化实现》的第四讲。

在上一讲中,我们解决了那些无法被 CRUD 囊括的复杂业务逻辑。今天,我们将目光转向数据传输的效率问题。

在日常开发中,你是否遇到过这样的“拉扯”场景:

场景 A:前端开发了一款 App,在“用户列表页”只需要展示用户的头像昵称

后端:直接复用了GetUser接口,返回了包含身份证号家庭住址注册时间最后登录IP等 50 多个字段的超级大 JSON。

前端:抱怨说:“我就要两个字段,你给我几 KB 的数据,用户在地铁上信号不好,加载太慢了!能不能给我单写一个GetUserSimple接口?”

后端:心里苦——“为了这点破事又要写个新接口?如果不写,是不是还得定一个UserSimpleDTO?”

这就陷入了 API 设计中经典的过度获取(Over-fetching)困境。

如果我们为每一种前端视图都定制一个后端接口,那就会陷入“BFF(Backend for Frontend)地狱”,后端变成了前端的“切图仔”;如果我们什么都不管,只返回全量数据,那就是对带宽和客户端内存的犯罪。

GraphQL 的出现很大程度上是为了解决这个问题,但为了这点需求引入整套 GraphQL 基础设施,成本又未免太高。

有没有一种办法,能在保持 RESTful 架构简洁性的同时,实现“按需索取”呢?

答案是肯定的。这就是今天我们要讲的API模式:字段掩码(Field Mask),也被称为“愿望清单(Wish List)”模式。

什么是字段掩码 (Field Mask)?

核心思想非常简单:客户端在请求中通过参数告诉服务端,“我只想要这些字段”,服务端据此对响应体进行裁剪。

架构模式视角

在架构设计领域,这种模式被称为Response Shaping(响应塑形)。它打破了“服务端定义契约,客户端被动接受”的传统模式,赋予了客户端(消费者)定义数据形态的权力。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/27 18:22:19

你的大脑是 CPU,别让 AI 把它挂起 (WAIT)

大家好,我是Tony Bai。先问一个扎心的问题:当你给 ChatGPT、Cursor 或 Claude Code 发送了一个复杂的 Prompt 之后,接下来的 30 秒到 1 分钟里,你在干什么?我观察过很多开发者,90% 的人是这样的&#xff1a…

作者头像 李华
网站建设 2026/4/23 8:15:32

Kafka Exporter终极指南:快速搭建企业级监控体系 [特殊字符]

Kafka Exporter终极指南:快速搭建企业级监控体系 🚀 【免费下载链接】kafka_exporter Kafka exporter for Prometheus 项目地址: https://gitcode.com/gh_mirrors/ka/kafka_exporter 想要实时掌握Kafka集群的健康状态吗?Kafka Exporte…

作者头像 李华
网站建设 2026/4/17 5:45:25

FMPy入门指南:5步掌握Python FMU仿真技术

FMPy入门指南:5步掌握Python FMU仿真技术 【免费下载链接】FMPy Simulate Functional Mockup Units (FMUs) in Python 项目地址: https://gitcode.com/gh_mirrors/fm/FMPy FMPy是一款功能强大的Python库,专门用于仿真功能性模型单元(F…

作者头像 李华
网站建设 2026/4/18 7:00:39

桌面版脑图:离线思维导图工具的终极指南 [特殊字符]

桌面版脑图:离线思维导图工具的终极指南 🚀 【免费下载链接】DesktopNaotu 桌面版脑图 (百度脑图离线版,思维导图) 跨平台支持 Windows/Linux/Mac OS. (A cross-platform multilingual Mind Map Tool) 项目地址: https://gitcode.com/gh_mi…

作者头像 李华
网站建设 2026/4/23 13:32:07

火山引擎AI大模型实战:基于Qwen-Image的高精度图像生成方案

火山引擎AI大模型实战:基于Qwen-Image的高精度图像生成方案 在数字内容爆炸式增长的今天,广告、电商、游戏等行业对高质量视觉素材的需求已远超传统设计团队的产能极限。一个运营人员想为春季新品生成一组“碎花连衣裙在樱花树下”的海报,过去…

作者头像 李华
网站建设 2026/4/18 12:09:34

BaiduPCS-Go命令行工具完整指南:快速掌握百度网盘终端操作

BaiduPCS-Go命令行工具完整指南:快速掌握百度网盘终端操作 【免费下载链接】BaiduPCS-Go 项目地址: https://gitcode.com/gh_mirrors/baid/BaiduPCS-Go 还在为百度网盘网页版的繁琐操作而烦恼吗?想要通过命令行高效管理云端文件?Baid…

作者头像 李华