news 2026/5/5 22:05:03

Vue项目中Axios封装实战指南(兼容Vue2/Vue3)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vue项目中Axios封装实战指南(兼容Vue2/Vue3)

前言:在Vue项目开发中,Axios是最常用的HTTP请求库,但直接在组件中零散使用会导致代码冗余、错误处理不一致等问题。本文带来一套工业级Axios封装方案,涵盖请求/响应拦截、环境隔离、API统一管理、错误分类处理等核心功能,同时适配Vue2和Vue3,新手也能直接套用!

一、前置准备:安装Axios

首先确保项目中已安装Axios依赖,若未安装执行以下命令:

npm install axios --save # 或使用yarn(推荐) yarn add axios

提示:若项目使用Element UI/Plus作为UI组件库,建议同步安装(用于后续错误提示),Vue2安装Element UI,Vue3安装Element Plus。

提示:若项目使用Element UI/Plus作为UI组件库,建议同步安装(用于后续错误提示),Vue2安装Element UI,Vue3安装Element Plus。

二、核心封装:创建request.js工具类

src/utils/目录下新建request.js文件,这是Axios封装的核心文件,包含实例创建、拦截器配置、通用请求方法封装等功能。

2.1 完整封装代码(Vue3+Element Plus版本)

import axios from 'axios' // 引入UI组件库的提示组件(用于错误/成功提示) import { ElMessage, ElMessageBox } from 'element-plus' // Vue3状态管理:Pinia(Vue2替换为Vuex) import { useUserStore } from '@/stores/user' // 引入路由实例(用于Token过期跳转登录页) import router from '@/router' /** * 1. 创建Axios实例 * 核心作用:统一配置基础请求地址、超时时间、默认请求头 */ const service = axios.create({ // 基础请求地址(从环境变量中获取,实现环境隔离) baseURL: import.meta.env.VITE_API_BASE_URL, timeout: 10000, // 请求超时时间:10秒 headers: { 'Content-Type': 'application/json;charset=utf-8' // 默认请求头:JSON格式 } }) /** * 2. 请求拦截器:请求发送前的统一处理 * 核心功能:添加Token、过滤无效参数、防止重复请求(可选) */ service.interceptors.request.use( (config) => { // 2.1 给请求头添加Token(后端约定字段,通常为Authorization) const userStore = useUserStore() if (userStore.token) { // 格式:Bearer + Token(后端若有其他格式可调整) config.headers.Authorization = `Bearer ${userStore.token}` } // 2.2 处理GET请求参数:过滤空值(可选,根据业务需求) if (config.method === 'get' && config.params) { config.params = Object.fromEntries( Object.entries(config.params).filter(([_, value]) => { // 过滤 undefined、null、空字符串 return value !== undefined && value !== null && value !== '' }) ) } return config }, (error) => { // 请求拦截器错误:如参数格式错误、网络未连接等 console.error('请求拦截器异常:', error) ElMessage.error('请求初始化失败,请检查网络或参数') return Promise.reject(error) } ) /** * 3. 响应拦截器:请求返回后的统一处理 * 核心功能:统一解析响应数据、错误码处理、Token
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/2 19:50:09

Docker 网络架构概述

文章目录 1. Docker 网络架构概述 一、Linux 内核网络命名空间(Network Namespace):容器网络隔离的“独立房间” 1. 原理拆解 2. Docker 中的应用 3. 通俗类比 4. 实操验证(Linux 命令直接感受 netns) 二、veth pair 虚拟网卡对:容器与外部通信的“专用网线” 1. 原理拆解…

作者头像 李华
网站建设 2026/5/2 19:53:40

基于大数据爬虫的起点小说网数据的文本月票分析系统

文章目录项目简介系统截图大数据系统开发流程主要运用技术介绍参考文献结论源码文档获取定制开发/同行可拿货,招校园代理 :文章底部获取博主联系方式!项目简介 .数据采集 设计网络爬虫,设置爬取规则,获取起点小说网的小说数据。 …

作者头像 李华
网站建设 2026/5/2 19:53:00

Lucky Draw:重新定义活动抽奖体验的开源解决方案

你是否曾经为活动抽奖环节的繁琐操作而头疼?从名单整理到奖项设置,再到现场控制,每一个环节都可能成为活动的"雷区"。传统抽奖工具要么功能复杂难上手,要么缺乏透明度引发质疑。现在,这一切都将因为 Lucky D…

作者头像 李华
网站建设 2026/5/2 19:51:16

WAVE三缸发动机模拟与改进:基于MATLAB的建模、仿真与优化分析

WAVE三缸发动机模拟与改进:基于MATLAB的建模、仿真与优化分析 摘要 随着全球排放法规的日益严苛和燃油经济性要求的不断提升,小排量三缸涡轮增压发动机因其结构紧凑、摩擦损失小、低速扭矩表现好等优点,在中低端乘用车市场得到了广泛应用。然而,三缸发动机固有的往复惯性…

作者头像 李华