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) => {})
相关推荐
若安程序开发4 分钟前
WEBweb前端OPPO手机商城网站项目
前端·智能手机
范德萨_6 分钟前
JavaScript 实用技巧(总结)
开发语言·前端·javascript
执携15 分钟前
Vue Router (匹配当前路由的链接和类名配置)
前端·javascript·vue.js
若安程序开发26 分钟前
web华为商城前端项目4页面
前端·华为
一枚前端小能手38 分钟前
🏷️ HTML 属性参考 - 常用与全局属性的行为、兼容性与最佳实践
前端·javascript·html
付十一1 小时前
更新!Figma MCP + Cursor:大前端时代的UI到代码自动化
android·前端·ai编程
万岳科技程序员小金1 小时前
多端统一的教育系统源码开发详解:Web、小程序与APP的无缝融合
前端·小程序·软件开发·app开发·在线教育系统源码·教育培训app开发·教育培训小程序
软件架构师-叶秋1 小时前
Vue3+tyepescript+ElementPlus+Axios前端技术栈
前端·vue3·elementplus
AAA阿giao1 小时前
HTML/CSS/JS 页面渲染机制:揭秘浏览器如何将平凡代码点化为视觉魔法
前端·css·html
lichenyang4531 小时前
从零到一:编写一个简单的 Umi 插件并发布到 npm
前端·react.js·前端框架