news 2026/5/1 8:16:08

【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/5/1 5:44:00

Display Driver Uninstaller终极指南:一键彻底清理显卡驱动残留

你是否曾经因为显卡驱动冲突而烦恼?系统频繁蓝屏、游戏卡顿掉帧、新驱动安装失败,这些问题往往源于旧驱动的残留文件。Display Driver Uninstaller(DDU)就是为解决这些顽固问题而生的专业级驱动清理工具,能够彻底清除A…

作者头像 李华
网站建设 2026/4/30 11:54:29

微PE启动盘运行Python脚本测试ACE-Step基本功能:极简验证法

微PE启动盘运行Python脚本测试ACE-Step基本功能:极简验证法 在一台老旧工控机上,没有显卡、系统陈旧、连管理员权限都没有——你却需要当场验证一个AI音乐生成模型是否可用。安装PyTorch?依赖冲突报错;配置环境变量?权…

作者头像 李华
网站建设 2026/5/1 4:44:02

Wan2.2-T2V-A14B与JLink驱动无关,但调试技巧可借鉴

Wan2.2-T2V-A14B与JLink驱动无关,但调试技巧可借鉴 在AI生成内容(AIGC)浪潮席卷影视、广告和虚拟现实的今天,文本到视频(Text-to-Video, T2V)技术正从实验室走向工业化落地。传统视频制作依赖导演、摄像、剪…

作者头像 李华
网站建设 2026/4/30 15:40:49

泉盛UV-K5/K6如何突破硬件限制?LOSEHU固件技术解析

泉盛UV-K5/K6如何突破硬件限制?LOSEHU固件技术解析 【免费下载链接】uv-k5-firmware-custom 全功能泉盛UV-K5/K6固件 Quansheng UV-K5/K6 Firmware 项目地址: https://gitcode.com/gh_mirrors/uvk5f/uv-k5-firmware-custom 在开源社区的技术推动下&#xff0…

作者头像 李华
网站建设 2026/5/1 1:10:20

Beyond Compare 5密钥生成技术解密:从逆向工程到实战激活

Beyond Compare 5密钥生成技术解密:从逆向工程到实战激活 【免费下载链接】BCompare_Keygen Keygen for BCompare 5 项目地址: https://gitcode.com/gh_mirrors/bc/BCompare_Keygen 还在为Beyond Compare 5的授权验证而困扰?这款被誉为文件对比神…

作者头像 李华