vite热更新时,页面自动http请求报错的问题

描述

vite + axios

页面修改代码后, vite进行热更新, 当onMounted中进行了http请求, 请求时报错

原因

封装axios时, 设置响应拦截器, 当返回了res.data时, 下一次热更新时, 进入响应拦截器的对象就是res.data对象, 而非res对象

ty 复制代码
axios.interceptors.response.use(
  (res: AxiosResponse<any, any>) => {
    return new Promise((resolve, reject) => {
      // 状态码判断....

      return resolve(res)
      // return resolve(res.data)		// 返回res.data会导致热更新后接口请求报错
    })
  },
	(error) => {
    console.error('>>> response error', error)
    // 响应码判断....
   
    return Promise.reject(error)
  }
)

解决

axios响应拦截器中直接返还res对象

在调用api函数后就需要多一层解析过程

可以再封装一个请求对象, 函数中返还res.data, 示例:

复制代码
const http = {
  get(url, params) {
    return new Promise((resolve, reject) => {
      NProgress.start()
      axios
        .get(url, { params })
        .then((res) => {
          NProgress.done()
          resolve(res.data)
        })
        .catch((err) => {
          NProgress.done()
          reject(err)
        })
    })
  },
  post(url, params) {
    return new Promise((resolve, reject) => {
      NProgress.start()
      axios
        .post(url, params)
        .then((res) => {
          NProgress.done()
          resolve(res.data)
        })
        .catch((err) => {
          NProgress.done()
          reject(err)
        })
    })
  },
  put(url, params, removeId = true) {
    // 移除params中的ID字段
    if (removeId && params.id) {
      params.id = undefined
    }
    return new Promise((resolve, reject) => {
      NProgress.start()	// 进度条插件, 可以删除
      axios
        .put(url, params)
        .then((res) => {
          NProgress.done()
          resolve(res.data)
        })
        .catch((err) => {
          NProgress.done()
          reject(err)
        })
    })
  },
  delete(url) {
    return new Promise((resolve, reject) => {
      NProgress.start()
      axios
        .delete(url)
        .then((res) => {
          NProgress.done()
          resolve(res.data)
        })
        .catch((err) => {
          NProgress.done()
          reject(err)
        })
    })
  },
}

// 使用
const api = {
  // 登录
  login: (params) => http.post('/api/v1/base/login', params),
}

api.login({...参数}).then((resData) => {})
相关推荐
zhensherlock11 小时前
Protocol Launcher 系列:Tally 快速计数器的深度集成
前端·javascript·typescript·node.js·自动化·github·js
AC赳赳老秦11 小时前
OpenClaw权限管理实操:团队共享Agent,设置操作权限,保障数据安全
服务器·开发语言·前端·javascript·excel·deepseek·openclaw
光影少年12 小时前
Polyline 组件如何绘制渐变区域?
前端·javascript·掘金·金石计划
Pkmer12 小时前
古法编程: React思维模型快速建立
前端·react.js
jiayong2312 小时前
第 38 课:任务列表里高亮当前正在查看详情的任务
开发语言·前端·javascript·vue.js·学习
anOnion12 小时前
构建无障碍组件之Spinbutton Pattern
前端·html·交互设计
古城小栈12 小时前
hey 你好 “压测”
http·golang·开源
程序员Better13 小时前
前端成功转型AI全栈,我踩过的坑都替你填上了
前端·后端·ai编程
兔子零102413 小时前
GPT-5.5 与 DeepSeek-V4:大模型竞争的本质,正在从“谁更强”变成“谁让成本更低”
前端·javascript·后端
Daybreak13 小时前
幽灵依赖:本地跑得好好的,线上部署却炸了
前端