Axios捕获错误返回的是JavaScript错误而不是服务器响应。
创始人
2024-09-28 15:30:18
0

要解决Axios捕获错误返回的是JavaScript错误而不是服务器响应的问题,可以使用Axios的拦截器来处理错误响应。以下是一个示例代码:

import axios from 'axios';

// 创建一个 Axios 实例
const instance = axios.create({
  baseURL: 'https://api.example.com',
});

// 添加响应拦截器
instance.interceptors.response.use(
  // 请求成功时的处理
  response => {
    return response;
  },
  // 请求错误时的处理
  error => {
    // 判断是否为服务器响应错误
    if (error.response) {
      // 在此处可以根据服务器返回的错误状态码进行相应处理
      console.log('服务器响应错误:', error.response.data);
    } else {
      // 在此处可以处理其他类型的错误,比如网络错误
      console.log('其他类型错误:', error.message);
    }

    // 返回一个 Promise.reject(),以便在调用处可以继续捕获错误
    return Promise.reject(error);
  }
);

// 发送请求
instance.get('/api/users')
  .then(response => {
    // 处理成功响应
    console.log('成功响应:', response.data);
  })
  .catch(error => {
    // 处理错误响应
    console.log('捕获错误:', error);
  });

在上面的代码中,我们创建了一个Axios实例并添加了一个响应拦截器。在拦截器的请求错误处理逻辑中,我们通过判断error.response是否存在来确定是否为服务器响应错误。如果是服务器响应错误,可以根据需要进行相应的处理。如果不是服务器响应错误,那么可能是其他类型的错误,比如网络错误,我们也可以在此处进行处理。

最后,我们通过返回一个Promise.reject(error)来让调用处继续捕获错误。这样,在调用处使用.catch()方法时,将能够捕获到服务器响应错误或其他类型的错误。

请注意,上述代码仅为示例,实际应用中可能需要根据具体需求进行相应的修改和优化。

相关内容

热门资讯

4分钟外挂!边锋微信小程序,四... 4分钟外挂!边锋微信小程序,四川途游辅助软件下载,2025新版(有挂方式)-哔哩哔哩1、下载好四川途...
第4分钟普及!家乡大二辅助,四... 第4分钟普及!家乡大二辅助,四川游戏家园通用辅助(其实有挂)-哔哩哔哩1、四川游戏家园通用辅助系统规...
第四分钟外挂!皮皮跑胡子修改器... 第四分钟外挂!皮皮跑胡子修改器,友友联盟免费辅助器,安装教程(有挂方法)-哔哩哔哩1、进入到友友联盟...
第8分钟详情!方片十三张源码,... 第8分钟详情!方片十三张源码,河洛杠次脚本开发(一贯有挂)-哔哩哔哩1)河洛杠次脚本开发辅助挂:进一...
1分钟外挂!传送屋激k有挂吗,... 1分钟外挂!传送屋激k有挂吗,兴动互娱辅助工具,解密教程(有挂分析)-哔哩哔哩1、超多福利:超高返利...
第6分钟解谜!山西扣点点智能辅... 第6分钟解谜!山西扣点点智能辅助器软件,决战卡五星辅助(一直是真的挂)-哔哩哔哩1、玩家可以在山西扣...
第五分钟推荐!开心泉州免费辅助... 第五分钟推荐!开心泉州免费辅助器,友友联盟免费辅助器(真是真的有挂)-哔哩哔哩1、完成开心泉州免费辅...
六分钟外挂!指尖四川小程序辅助... 六分钟外挂!指尖四川小程序辅助,八闽福建辅助,微扑克教程(存在有挂)-哔哩哔哩暗藏猫腻,小编详细说明...
第4分钟必备!潮汕木虱辅助下载... 第4分钟必备!潮汕木虱辅助下载,天天飞小鸡辅助(一贯存在有挂)-哔哩哔哩1、操作简单,无需注册,只需...
七分钟外挂!浙江宝宝游戏辅助下... 七分钟外挂!浙江宝宝游戏辅助下载,小程序牵手跑的辅助,安装教程(有挂解惑)-哔哩哔哩1)浙江宝宝游戏...