尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

从 PHP 到 AI + Golang,程序员自救转型手记(二十一):网络请求封装优化

从 PHP 到 AI + Golang,程序员自救转型手记(二十一):网络请求封装优化
📅 发布时间:2026/7/5 1:26:12

这是一个系列 Blog,作者将以一个 PHP 全栈工程师的身份,利用 AI 工具(claude code、codex、deepseek、豆包等):从零开始学习 golang 语言,并最终完成 ai-go-mall(github | gitee)开源项目的制作,全程记录分享。

在上一期,我们进行了 “前端点选验证码组件实现”,本期将完成:网络请求封装优化

网络请求封装优化

请求选项使用单独的参数传递

目前,如果需要使用我们自定义的请求选项,写法如下的requestOptions:

exportfunctioncheckClickCaptcha(data:ClickRequest,apiBaseURL?:string){returnrequest({url:'/common/captcha/verify',method:'POST',requestOptions:{loading:true,cancelDuplicate:true,showErrorMessage:false,},})}

即,使用request函数的第一个参数嵌套一个requestOptions来完成配置,我希望改为使用单独的参数进行传递,如下:

exportfunctioncheckClickCaptcha(data:ClickRequest){returnrequest({url:'/common/captcha/verify',method:'POST',data,},{loading:true,cancelDuplicate:true,showErrorMessage:false,})}

参数 1 是axios的请求配置,参数 2 是我们自定义的请求选项,将其独立出来可读性、类型、扩展性、维护性全方位更优;以上内容是思路,同时是提示词,直接发送给 cc:

● 重构完成。改动总结如下: 修改的文件1. src/utils/request.ts - 删除了 RequestConfig 接口(已不需要,直接使用 AxiosRequestConfig) - request 函数签名从 request(config: RequestConfig)改为 request(config: AxiosRequestConfig, options?: RequestOptions)- 内部将 options 合并到 config 的 requestOptions 字段上,拦截器逻辑无需任何改动2. src/api/common.ts - checkClickCaptcha 中的 requestOptions 从第一个参数嵌套中提取为独立的第二个参数: // 之前 request({url:'...', requestOptions:{showErrorMessage:false}})// 之后 request({url:'...'},{showErrorMessage:false})无需改动的文件 - src/api/admin/index.ts — 未使用 requestOptions,现有的单参数调用完全兼容 - 其他不涉及 requestOptions 的调用方同样无需改动,因为 AxiosRequestConfig 就是之前第一个参数去掉 requestOptions 后的类型 ✻ Bakedfor50s

人工review没发现不对的,其实总共也没改几行,反而提示词写了一大堆,失算了,😂😂

后端接口响应中的字段命名方式自动转为 camelCase

各个语言的服务端 json 字段命名,还有网络传输的惯例字段命名方式都是snake_case,但是前端一般使用camelCase访问/存储字段值,所以在网络请求封装中对命名方式进行转换是比较常见的做法,这里要求 CC 增加转换字段命名方式的开关,默认打开,然后实现这个功能:

全部完成。以下是变更总结:

变更清单
src/utils/request.ts— 核心改造

变更说明
import { camelCase }复用已有的 lodash-es,无需新依赖
convertCase?: boolean新增请求选项,默认 true(开关打开)
keysToCamelCase()递归转换函数,处理对象、数组、嵌套结构
响应拦截器 L190-193在 response.data.data 上自动执行转换

接口 + Store + 模板统一改名

文件变更
src/stores/interface/index.tslast_login_at → lastLoginAt,last_login_ip → lastLoginIp
src/stores/adminInfo.ts初始 state 同步改为 camelCase
src/layouts/admin/components/navMenu.vue模板变量引用改为 adminInfo.lastLoginAt

使用方式:

// 默认:自动转换(开关打开)

request({ url: '/admin/init', method: 'GET' })

// 某个接口不需要转换时,显式关闭

request({ url: '/some/api', method: 'GET' }, { convertCase: false })

现在前端所有接口的响应字段命名都是统一的camelCase了,不再有风格不一致的问题。

review时,我直接让它把请求时的camelCase也反向转为snake_case(受同一开关控制),至此前后端命名风格彻底解耦,本来是大型项目才标配的功能,也是让 AI 随手就搞了。

现在起:

  1. API响应snake_case将被转换为camelCase;
  2. 请求API时,传递camelCase(包括data和params)会转换为snake_case。

前端可以总是使用camelCase了,非常舒服,比如:

  1. 访问响应数据时,接口返回了:res.data.data.admin_info.last_login_at字段,可以使用res.data.data.adminInfo.lastLoginAt访问响应数据;
  2. 发起请求时,data是:{data: {adminInfo: {lastLoginAt: '2023-05-01'}},将被转换为:{data: {admin_info: {last_login_at: '2023-05-01'}}发送。

相关新闻

  • # Qidi Agent v2.1.0:自适应编排 + 涌现度量,让多 AI 协作真正“1+1>2“
  • 监督学习:机器学习中最核心的方法论
  • RAM 和 SSD 哪个更重要?买 VPS、云服务器到底该优先选内存还是硬盘?

最新新闻

  • Linux top/ps 命令实战:5分钟定位CPU 100%与内存泄漏的进程
  • 旋转向量,旋转矩阵,四元数,欧拉角之间的转换公式
  • C++ STL 容器底层实现与迭代器失效规则总结
  • AI替代人力是假象?微软派6000人驻场,Ford召回老工程师,人力价值凸显!
  • 2026年6月好用的CNC加工服务商
  • SRS 4.0 HTTP回调实战:Spring Boot 2.3.7 实现7种事件鉴权与日志记录

日新闻

  • 基于YOLOv12的番茄成熟度智能检测系统开发
  • 终极RimWorld模组管理指南:用RimSort告别模组冲突烦恼
  • AI Agent框架开发:从理论到实践的完整指南

周新闻

  • 基于YOLOv12的番茄成熟度智能检测系统开发
  • 终极RimWorld模组管理指南:用RimSort告别模组冲突烦恼
  • AI Agent框架开发:从理论到实践的完整指南

月新闻

  • 2026年6月公司网站搭建最新热门渠道测评:四大低成本/零代码平台对比+避坑
  • 【Linux】Linux arm 编译QT程序,出现expected “}“报错
  • 【MATLAB例程】四基站二维AOA定位与距离辅助增强对比仿真。基于角度观测和测距修正的固定目标平面定位精度分析

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号