跳到主要内容
极客日志极客日志面向AI+效率的开发者社区
首页博客GitHub 精选镜像工具UI配色美学隐私政策关于联系
搜索内容 / 工具 / 仓库 / 镜像...⌘K搜索
注册
博客列表
JavaScript大前端

Axios 错误处理的设计与进阶封装,实现网络层面数据与状态解耦

综述由AI生成探讨了前端项目中网络错误处理下沉至 Axios 层的重要性及实施方案。通过 Axios 拦截器统一处理 HTTP 错误与业务错误,实现了数据与状态的解耦。文章介绍了拦截器的基础应用、错误分级策略映射设计以及错误对象标准化方法,旨在构建可维护、可扩展的网络请求基础设施,减少业务层代码污染并提升系统健壮性。

并发大师发布于 2026/4/6更新于 2026/5/2035 浏览
Axios 错误处理的设计与进阶封装,实现网络层面数据与状态解耦

Axios 错误处理的设计与进阶封装,实现网络层面数据与状态解耦

图片

有这样一句话:在前端项目中,网络请求失败不是异常,而是常态。真正拉开项目工程质量差距的,不是会不会用 axios,而是如何设计一套可维护、可扩展、可协作的网络错误处理体系。成熟的项目组有现成可用的 axios 网络封装设计,不成熟的项目组网络错误处理原始而杂乱,很多开发者在成熟的项目组开发了多年,依然不了解 Axios 错误处理的设计封装,只处在知道有这个东西,而不知道如何设计的状态下。本文围绕 Axios 的拦截器机制,系统性分析可配置、可分级、可扩展的网络请求实战封装策略。

一、为什么网络错误处理一定要下沉到 Axios 层

在项目中,如果常规错误处理放在业务层,就会需要给每个 async/await 都要写一段 try-catch,同一种错误(如 token 过期)被处理 N 次,UI 提示风格难以统一,后续想要改动极其痛苦:

// 典型的业务层污染
async function loadList() {
  try {
    const res = await getList();
    list.value = res.data;
  } catch (e) {
    ElMessage.error('请求失败');
  }
}

这肯定是不可取的,应该将错误分级并合并统一处理。对于网络错误的判断逻辑、分类、兜底策略,本就应该属于请求基础设施层。

二、Axios 拦截器 interceptors

Axios 提供了两个关键拦截器,分别是请求拦截器和响应拦截器,可以用来行使不同的职责。

图片

1、拦截器的基础应用

网络请求一般有两大类失败,其一是 HTTP / 网络层错误,比如断网、请求超时、上游错误(500/502/503)等。其二是业务层错误,比如 code !== 0(响应状态码是 200,但业务状态异常)、token 过期、权限问题等。

// src/utils/api.js
import axios from 'axios';
import { ElMessage } from 'element-plus';

// 创建 axios 实例
const request = axios.create({
  baseURL: import.meta.env.VITE_API_BASE_URL || '/api',
  timeout: 10000,
});

// 请求拦截器(可选:添加 token 等)
request.interceptors.request.use(
  (config) => {
    // 例如:从 localStorage 获取 token 并添加到请求头
    const token = localStorage.getItem('token');
    if (token) {
      config.headers.Authorization = `Bearer ${token}`;
    }
    return config;
  },
  (error) => {
    return Promise.reject(error);
  }
);

// 响应拦截是集中处理错误的核心
request.interceptors.response.use(
  (response) => {
    const { code, message, data } = response.data;
    if (code !== 0) {
      return Promise.reject({ type: 'business', code, message });
    }
    return data;
  },
  (error) => {
    const { response } = error;
    if (response) {
      // 有响应(HTTP 状态码 4xx / 5xx)
      switch (response.status) {
        case 400:
          ElMessage.error('请求参数错误');
          break;
        case 401:
          ElMessage.error('未授权,请重新登录');
          // 可跳转到登录页
          // window.location.href = '/login';
          break;
        case 403:
          ElMessage.error('拒绝访问');
          break;
        case 404:
          ElMessage.error('请求资源不存在');
          break;
        case 500:
          ElMessage.error('服务器内部错误');
          break;
        default:
          ElMessage.error(`请求失败:${response.status}`);
      }
    } else if (error.request) {
      // 请求已发出但无响应(如网络错误、超时)
      ElMessage.error('网络异常,请检查网络连接');
    } else {
      // 其他错误(如配置错误)
      ElMessage.error('请求配置错误');
    }
    return Promise.reject(error);
  }
);

export default request;

此时业务层已经做到了数据与状态的解耦,状态问题和错误信息全部在拦截器阶段处理,返回给业务调用接口位置的只有数据:

// 在响应拦截器里面,返回的是 response.data.data,所以业务层里面只会拿到数据
const data = await api.getUser();

这样业务层就不用关心 HTTP 状态码和后端返回的具体结构,也不用对请求错误类型进行具体的区分了。

2、错误分级和策略映射的设计

错误的严重程度是有等级的,不应该把所有的错误都按相同的方式处理,比如 401,一般情况下应该去实现用户无感刷新,请求失败再提示用户重新登陆。

只需要加上一个简单的策略映射设计:

const errorHandlers = {
  401() {
    logout();
    router.push('/login');
  },
  403() {
    ElMessage.error('没有权限');
  },
  default(err) {
    ElMessage.error(err.message || '请求失败');
  },
};

并在拦截器中统一调度:

function handleBusinessError(err) {
  const handler = errorHandlers[err.code] || errorHandlers.default;
  handler(err);
}

这样就能根据状态码的不同,映射不同的处理方法,长期维护和拓展问题也解决了。

3、错误对象标准化

很多项目后期痛苦的根源是 error 有时候是 string,有时候是 AxiosError,有时候是后端对象,所以需要永久地将错误处理的复杂度从业务层转移到基础设置层(即 Axios)。以此来实现一个架构层面的收益。

比如定义一个标准错误结构(这部分代码仅 ts 需要):

interface AppError {
  type: 'network' | 'business';
  code?: number;
  message: string;
  raw?: any;
}

然后在 Axios 层构造,举个例子:

axios.interceptors.response.use(
  (res) => {
    if (res.data.code !== 0) {
      return Promise.reject({
        type: 'business',
        code: res.data.code,
        message: res.data.msg,
        raw: res,
      });
    }
    return res.data.data;
  },
  (error) => {
    return Promise.reject({
      type: 'network',
      message: '网络异常,请稍后重试',
      raw: error,
    });
  }
);

那么在业务层就只需要面对一种 error 类型了,不用操心错误类型,业务代码降维:

try {
  await api.save();
  ElMessage.success('保存成功');
} catch (err) {
  ElMessage.error(err.message);
}

三、结语

一个成熟的 Axios 错误处理体系,应该能做到错误集中处理,业务代码干净,错误分级,有明确策略,错误结构统一,方便扩展,自然接入登录、权限、数据监控等模块。**错误处理不是异常流程,而是系统设计的一部分。**做好网络层的错误处理,实现数据与状态的解耦,会让业务层开发大有裨益。

目录

  1. Axios 错误处理的设计与进阶封装,实现网络层面数据与状态解耦
  2. 一、为什么网络错误处理一定要下沉到 Axios 层
  3. 二、Axios 拦截器 interceptors
  4. 1、拦截器的基础应用
  5. 2、错误分级和策略映射的设计
  6. 3、错误对象标准化
  7. 三、结语
  • 💰 8折买阿里云服务器限时8折了解详情
  • Magick API 一键接入全球大模型注册送1000万token查看
  • 🤖 一键搭建Deepseek满血版了解详情
  • 一键打造专属AI 智能体了解详情
极客日志微信公众号二维码

微信扫一扫,关注极客日志

微信公众号「极客日志V2」,在微信中扫描左侧二维码关注。展示文案:极客日志V2 zeeklog

更多推荐文章

查看全部
  • Qwen-Image-2512:消费级 GPU 支持的 AI 文生图工具
  • 飞书与 OpenClaw 接入指南:无需服务器通过长连接运行机器人
  • 软件开发核心思维:抽象与具体的跨语言实战解析
  • 哈希表、Set 与 Map 基础算法总结
  • AI 大模型专题报告:发展迎来爆发期,引领 AI 新时代
  • Visual Studio 使用 GitHub Copilot 与 IntelliCode 辅助编码
  • OpenClaw Web Search 工具配置与搜索渠道详解
  • OpenClaw Web Search 搜索工具配置与渠道详解
  • 大模型推理框架 llama.cpp 开发流程与常用函数解析
  • C/C++ 内存分布与动态管理
  • 大模型开发环境搭建:Python 与 PyCharm 安装指南
  • 嵌入式与工控核心技术解析:C#, PLC, STM32, FPGA, DSP 及 HMI
  • OpenWork 开源平替 Claude Cowork:本地优先的 AI 协作方案
  • Linux 初识线程
  • Linux 信号机制详解:从除零到 SIGPIPE
  • OpenClaw 配置指南:定制专属 AI 助手
  • 基于 DrissionPage 的抖音评论数据自动化采集方案
  • ComfyUI 云服务器部署实战与优化指南
  • 前端代码质量保证与最佳实践
  • C++ 智能指针:内存管理的自动化机制

相关免费在线工具

  • Keycode 信息

    查找任何按下的键的javascript键代码、代码、位置和修饰符。 在线工具,Keycode 信息在线工具,online

  • Escape 与 Native 编解码

    JavaScript 字符串转义/反转义;Java 风格 \uXXXX(Native2Ascii)编码与解码。 在线工具,Escape 与 Native 编解码在线工具,online

  • JavaScript / HTML 格式化

    使用 Prettier 在浏览器内格式化 JavaScript 或 HTML 片段。 在线工具,JavaScript / HTML 格式化在线工具,online

  • JavaScript 压缩与混淆

    Terser 压缩、变量名混淆,或 javascript-obfuscator 高强度混淆(体积会增大)。 在线工具,JavaScript 压缩与混淆在线工具,online

  • Base64 字符串编码/解码

    将字符串编码和解码为其 Base64 格式表示形式即可。 在线工具,Base64 字符串编码/解码在线工具,online

  • Base64 文件转换器

    将字符串、文件或图像转换为其 Base64 表示形式。 在线工具,Base64 文件转换器在线工具,online