当前位置: 首页 > news >正文

服务端之NestJS接口响应message编写规范详解、写给前后端都舒服的接口、API提示信息标准化

MENU

  • 前言
  • 定义
  • 提示信息设计原则
  • 提示信息风格分类
  • 提示信息模板化设计
  • 国际化与多语言支持
  • 最佳实践
  • 参考示例(NestJS响应)
  • 总结
  • 统一风格示例清单推荐
  • API响应message清单(可直接使用)


前言

在现代后端开发中,接口响应不仅仅是数据的传递,还承担着向前端或用户传递操作状态和结果的功能。一个规范、统一的message字段设计,可以显著提升系统的可维护性、前端开发效率和用户体验。


定义

响应结构示例(NestJS风格)

return {status: 200, // 可选,HTTP状态码message: '获取数据成功', // 提示信息data: {list, // 数据列表page: 1, // 当前页size: 10, // 每页数量total: list.length // 数据总数}
};

各字段作用

字段类型说明
statusnumberHTTP或自定义状态码,用于程序判断
messagestring操作反馈信息,可显示给用户或用于日志
dataobject实际返回的数据对象,包含列表、分页或其他信息

提示信息设计原则

简洁明了
1、不宜过长,一般3~12个汉字。
2、避免含糊不清的词,如“完成了”、“OK”等。


统一风格
1、同一项目接口建议使用统一动词+状态组合,例如:获取数据成功、数据加载完成。


上下文清晰
1、提示信息应体现操作对象或类型,如“用户列表获取成功”而不是“获取成功”。


可扩展与模板化
1、对于多类型数据返回,可使用模板化语法:

message: `${dataType}获取成功`

2、如 设备列表获取成功、订单数据获取成功


面向用户与面向开发分层
1、前端提示:简短易懂,强调用户操作状态。
2、后台日志 / 文档:正式、完整,便于排查接口状态。


提示信息风格分类

简洁风格(前端显示)

场景示例
通用成功获取数据成功、操作成功
列表数据数据加载完成、列表加载成功
数据更新更新成功、保存成功

正式 / 日志风格(后台接口 / 接口文档)

场景示例
数据获取数据已成功获取、列表数据已返回
数据更新数据更新操作已完成、保存操作成功
数据删除删除操作已完成、记录已成功删除

带数量 / 上下文提示

场景示例
列表数据已成功获取用户列表,共15条数据
分页数据列表数据获取成功,共10条记录,当前页1
操作反馈设备列表加载完成,共20条可用设备

带操作指引提示

场景示例
后续操作提示数据加载成功,可进行下一步操作
页面跳转提示数据获取成功,请查看详情
用户操作操作成功,数据已更新

提示信息模板化设计

模板
为了统一风格和减少重复代码,可设计模板:

function buildMessage(dataType: string, action: '获取' | '加载' | '更新' | '删除', extra?: string) {return `${dataType}${action}成功${extra ? `${extra}` : ''}`;
}// 示例
message: buildMessage('用户列表', '获取', `${list.length}`)

输出:用户列表获取成功,共10条


模板化好处:
1、统一风格,易维护
2、可动态生成提示内容
3、可适配多语言(国际化)


国际化与多语言支持

模板
在国际化项目中,message应使用 语言文件或翻译key,避免硬编码:

return {message: i18n.__('data.fetch_success'),  // 英文:Data fetched successfullydata
};

好处
1、适配不同语言
2、前端可直接展示翻译内容
3、后端日志仍可使用统一key便于排查


最佳实践

前端提示短小清晰
1、数据加载完成、获取数据成功


后台 / 日志提示正式完整
1、数据已成功获取、列表数据已返回


数量提示增加用户反馈
1、列表数据获取成功,共${list.length}条


模板化 + 动态内容
1、提高复用率,降低出错率


避免模糊词
1、不使用“OK”、“完成了”、“操作成功了”
2、必须明确操作对象、状态或数量


参考示例(NestJS响应)

return {status: 200,message: `用户列表获取成功,共 ${list.length}`,data: {list,page: 1,size: 10,total: list.length}
};

1、前端显示,用户列表获取成功,共10条
2、日志可记录status+message用于接口监控


总结

1、message字段是接口的重要组成部分,承担操作反馈和提示作用。
2、优化目标:简洁、统一、明确、可扩展、可国际化。
3、规范化提示信息:
3.1、前端提示:短小清晰,用户友好
3.2、后端日志 / 文档:正式完整,便于排查
3.3、可模板化,适应多接口、多数据类型
3.4、可动态添加数量或操作引导


统一风格示例清单推荐

类型示例message
数据获取获取数据成功 / 数据已成功获取 / 列表数据获取成功,共N条
数据更新更新成功/数据更新操作已完成
数据删除删除成功/记录已成功删除
操作提示数据加载成功,可进行下一步操作
列表提示用户列表获取成功,共 N条

API响应message清单(可直接使用)

1、前端提示(简洁直观)
获取数据成功数据加载完成操作成功保存成功更新成功删除成功


2、后端日志 / 正式风格(完整清晰)
数据已成功获取数据获取操作完成列表数据已返回数据更新操作已完成记录已成功删除请求已成功处理


3、列表类提示(带上下文)
用户列表获取成功设备列表获取成功订单列表获取成功日志记录获取成功配置数据获取成功


4、分页 / 带数量提示
列表数据获取成功,共${list.length}条用户列表加载完成,共${list.length}条数据获取成功,当前页${page}/共${totalPages}页数据加载成功,本页${list.length}条,总数${total}条查询成功,符合条件的数据共${total}条


5、操作提示 / 引导型
数据加载成功,可进行下一步操作操作成功,数据已更新删除成功,记录已移除保存成功,请刷新查看数据获取成功,请查看列表

http://www.dtcms.com/a/453067.html

相关文章:

  • 【开题答辩全过程】以 安康毛绒玩具展示及销售平台为例,包含答辩的问题和答案
  • H7-TOOL的I2C控制器主机模式的时钟扩展功能支持
  • Keil 单片机笔记1
  • 一个人做运营网站仿站网站开发
  • Linux -- 传输层协议TCP
  • 浅谈 Protobuf——高效、安全的跨语言通信基石
  • SpringBoot安全进阶:利用门限算法加固密钥与敏感配置
  • [工作流节点17] 数据校验与错误处理机制:让自动化更安全、更可靠
  • 佛山高端网站制作wordpress免费用户
  • 《SaaS双优实战:数据驱动下的体验迭代与性能攻坚全指南》
  • 人力资源管理的思维方式学习笔记6
  • Git--
  • 怎么做车载mp3下载网站企业案例网站
  • [论文阅读]PromptArmor: Simple yet Effective Prompt Injection Defenses
  • xx网站建设策划方案网站开发必须要要掌握的语言
  • SpringBoot13-小细节
  • K8S探针-Pod创建流程-kubeadm证书续期-VPA实战
  • SQLite 别名
  • wstunnel 实现ssh跳板连接
  • QML之四转圈等待指示器
  • TOGAF®标准与应对时代冲击的韧性架构
  • 【深入理解计算机网络06】数据链路层:详解信道划分与介质访问控制
  • ACL限制研发部允许总裁办
  • 个人网站建站指南东莞营销推广
  • 服务器架构模型
  • 【C++】stack与queue的使用与模拟实现
  • JSDoc注释
  • 第4章:函数调用(Function Calling / Tool Calling)—让 AI 调用你的 API
  • LLaVA-Video论文阅读
  • 精品课程网站建设意义北京小程序网站制作