Vue2 项目二次封装Axios

引言

在现代前端开发中,HTTP请求管理是构建健壮应用的核心能力之一。Axios作为目前最流行的HTTP客户端库,其灵活性和可扩展性为开发者提供了强大的基础能力。

1. 为什么要二次封装Axios?

1.1 统一项目管理需求

  • API路径标准化:通过baseURL统一管理接口前缀
  • 超时控制:全局设置合理超时时间(如5s)
  • 错误统一处理:集中管理网络异常和业务异常

1.2 拦截器核心作用

拦截器类型功能说明
请求拦截器处理请求头配置、添加Token、显示Loading动画
响应拦截器处理响应数据格式、隐藏Loading、统一错误提示、刷新Token等
请求拦截器
添加认证Token
处理Content-Type
显示加载状态
响应拦截器
处理响应数据
统一错误提示
刷新Token

1.3 扩展性优势

  • 便于后期添加全局缓存策略
  • 统一处理安全认证机制
  • 简化各组件中的请求代码

2. Axios与其他HTTP库对比

特性XMLHttpRequestfetchjQuery.ajaxAxios
Promise支持
拦截器机制
自动JSON转换手动处理
取消请求
浏览器兼容性全部现代浏览器全部现代浏览器

2. 基础封装实现

2.1 创建核心实例

// utils/request.js  
import axios from 'axios'  // 创建基础实例  
const service = axios.create({  baseURL: '/api',   // 为每个请求添加上 /api 前缀timeout: 10000,  // 超时时间 10秒headers: {  'X-Requested-With': 'XMLHttpRequest'  }  
})  export default service  

2.2 请求拦截器实现

service.interceptors.request.use((config) => {// Token处理const token = localStorage.getItem("token");if (token) {config.headers.Authorization = `Bearer ${token}`;}return config;
});

2.3 响应拦截器分层处理

service.interceptors.response.use((res) => {// 成功响应处理if (res.data.code === 200) {return res.data;} else {return Promise.reject(res.data.message);}},(error) => {// 网络错误处理const errorMessage = error.response?.data?.message || "网络异常";console.error("API Error:", errorMessage);return Promise.reject(errorMessage);}
);

3. 接口模块化配置

3.1 创建API模块

一般在项目中,会对 api 统一管理,通常放在 src/api 目录下,并对其分模块管理,然后在 index.js 中统一暴露:

src/
├─ api/
│  ├─ system.js    # 系统相关接口
│  ├─ user.js      # 用户模块接口
│  ├─ product.js   # 商品模块接口
│  └─ index.js     # 统一导出入口

product. js 中编写方法:

// src/api/product.js
import request from "@/utils/request";/*** 获取商品基础分类列表*/
export const getBaseCategoryList = () => {return request({url: "/product/getBaseCategoryList",method: "get"});
};

然后统一暴露:

// index.js
export * as productAPI from "./product";

3.2 跨域解决

为什么会出现跨域?
  1. 浏览器的同源策略:是重要的安全机制,限制以下行为的跨域访问:

    • AJAX请求
    • DOM访问
    • Cookie/Storage读取
  2. 同源判定标准:协议+域名+端口 完全一致 才被允许访问

http://localhost:8080 ≠ https://localhost:8080 // 协议不同
http://a.com:8080 ≠ http://a.com:9090         // 端口不同
Vue项目解决方案(开发环境)
// vue.config.js
module.exports = {devServer: {proxy: {"/api": {                   // 匹配所有以/api开头的请求target: "http://gmall-h5-api.atguigu.cn",  // 后端服务器地址changeOrigin: true,       // 允许跨域}}}
};

注意: 配置完 vue.config.js 后需要重新启动。

配置项作用说明必要性
target指定代理目标服务器地址必选
changeOrigin将请求头中的host改为目标地址,绕过浏览器同源检测必选
pathRewrite重写请求路径,处理接口前缀差异可选

3.3 测试接口调用

main.js 中测试:

import {productAPI} from "@/api";  // 调用接口    
productAPI.getBaseCategoryList().then((data) => {  console.log(data);  
})

可以在控制台中看到,数据被成功输出:

![[Pasted image 20250123233827.png]]

4. 总结

通过对 Axios 进行二次封装,可以有效提升项目的开发效率和代码质量。在封装过程中,通过统一 API 路径、超时控制以及拦截器机制,不仅能集中管理请求与响应的逻辑,还能优化接口调用的可维护性和可扩展性。此外,通过模块化接口设计和跨域代理配置,我们能够更好地满足前后端分离架构下的开发需求。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/67980.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Jmeter 动态参数压力测试时间段预定接口

🎯 本文档详细介绍了如何使用Apache JMeter进行压力测试,以评估预定接口在高并发场景下的性能表现。通过创建线程组模拟不同数量的用户并发请求,利用CSV文件动态配置时间段ID和用户token,确保了测试数据的真实性和有效性。文档中还…

Unity常用特性(Attribute)用法

一.UnityEngine命名空间 1.[Header(string)] inspector面板上给显示的字段上加一个描述 通常情况下,用于在 Inspector 窗口中创建字段的逻辑分组 public class AttributeTest : MonoBehaviour {[Header("public_field_num")]public int num; }2.[Tool…

vue项目的创建

运行第一个vue-cli应用程序 创建一个基于webpack模板的vue应用程序 vue init webpack 项目名根据自己需求选择 创建好之后如下 运行 cd vue01npm run dev运行之后如下 复制访问地址 : http://localhost:8080 停止服务 两次ctrlC 或者 一次ctrlc然后y idea中使用…

【技术杂谈】Arcgis调用天地图和卫星影像

Arcgis调用天地图和卫星影像 Arcgis调用天地图 1.注册用户官网地址:https://www.tianditu.gov.cn/在官网右上角找到“注册”,输入账号信息完成注册。 2.申请车成为天地图开发者在首页往下滑,找到开发资源下的成为开发者,填写好…

【ROS】RViz2源码分析(四):初始化、启动

【ROS】郭老二博文之:ROS目录 1、简述 RViz2在main函数中,首先注册日志处理函数; 将 RCLCPP_DEBUG 等日志记录函数,通过 rviz_common::set_logging_handlers() 注册到 rviz_common 中。然后,创建界面类 rviz_common::VisualizerApp,并执行初始化 vapp.init(argc, argv)…

【CS61A 2024秋】Python入门课,全过程记录P3(Week5 Sequences开始,更新于2025/1/23)

文章目录 关于基本介绍👋新的问题Week5Mon Sequences阅读材料 关于 个人博客,里面偶尔更新,最近比较忙。发一些总结的帖子和思考。 江湖有缘相见🤝。如果读者想和我交个朋友可以加我好友(见主页or个人博客&#xff0…

android手机应用连接热点后无法进行tcp连接

你在WifiNetworkSpecifer连接回调onavaliable里,再次调用bindProcessToNetwork试试,我这边模拟了一下,是可以建立tcp连接的 你的那个应用我一直没编译成功,你试试吧,应该这样是可以的 另一个同事找到了类似的方法&…

【华为路由的arp配置】

华为路由的arp配置 ARP:IP地址与MAC地址的映射。 R1: g0/0/0:10.1.1.254/24 g0/0/1:10.1.2.254/24 PC1: 10.1.1.1/16 PC2: 10.1.1.2/16 PC3: 10.1.2.3/16 动态ARP 查看PC1的arp表,可以看到,列表为空。 查看R1的arp表 在PC3上ping命令测…

SPDK vhost介绍

目录 1. vhost技术的背景与动机Virtio 介绍virtio-blk数据路径为例 2. vhost技术的核心原理2.1 vhost-kernel2.2 vhost-user举例 2.3 SPDK vhostvhost的优势IO请求处理数据传输控制链路调整 3. SPDK vhost的实现与配置3.1 环境准备3.2 启动SPDK vhost服务3.3 创建虚拟块设备3.4…

GPU 编程系列:内核网格与多维数据处理

GPU 编程系列:内核网格与多维数据处理 大家好,欢迎来到 GPU 编程系列的第三集!在这一集中,我们将深入探讨内核网格的概念,并展示如何利用多维网格来处理复杂的数据结构。 3 内核网格的基础 在上期节目中,…

电容的一些常用数值

如果是滤高频信号的小电容一般采用100nF 如果是滤低频信号的大电容一般采用10uF(10000nF) 比如这个LDO降压 两个一起用滤波效果会更好 如果想要供电引脚悬空,按理不能悬空,所以应该接大电阻接地,一般采用5.1KΩ 比如这个6Pin USB-TypeC的…

Apache Flink 概述学习笔记

一、引言 在大数据处理领域,Apache Flink 是一个极具影响力的开源流批一体化计算框架,它以其独特的架构和强大的功能,为大规模数据处理提供了高效、灵活的解决方案。 二、基本概念 Flink 是什么:Flink 是一个分布式流批处理框架…

Java面向对象专题

面向过程和面向对象的区别 面向过程:当事件比较简单的时候,利用面向过程,注重的是事件的具体的步骤/过程,注重的是过程中的具体的行为,以函数为最小单位,考虑怎么做。 面向对象:注重找“参与者”,将功能封装进对象,强调具备了功能的对象,以类/对象为最小单位,考虑…

业余无线电 对讲机常用频率使用

我自己的总结是,基本可以无忧使用: 144.035-145.800 146.000-148.000 430.000-431.900 432.240-435.000 438.000-439.000 50Mhz一般手台不支持,暂不记录。 以下为附录可以自行阅读,本文内容如有错误请留言指正。 特定波段…

linux 扩容

tmpfs tmpfs 82M 0 82M 0% /run/user/1002 tmpfs tmpfs 82M 0 82M 0% /run/user/0 [输入命令]# fdisk -lu Disk /dev/vda: 40 GiB, 42949672960 bytes, 83886080 sectors Units: sectors of 1 * 512 512 bytes Sector size (logi…

一个基于Python+Appium的手机自动化项目~~

本项目通过PythonAppium实现了抖音手机店铺的自动化询价,可以直接输出excel,并带有详细的LOG输出。 1.excel输出效果: 2. LOG效果: 具体文件内容见GitCode: 项目首页 - douyingoods:一个基于Pythonappium的手机自动化项目,实现了…

VMware虚拟机迁移到阿里云

VMware虚拟机迁移到阿里云是一个涉及多个步骤的过程,具体如下: 使用阿里云的服务器迁移中心(SMC)进行P2V或V2V迁移。如果是小型应用,可以通过制作镜像文件然后上传至阿里云OSS,并基于该镜像创建ECS实例。对…

(回溯分割)leetcode93 复原IP地址

#include<iostream> #include<vector> #include<string> #include<algorithm> using namespace std; //卡尔的图不是按照程序执行过程而是直接画程序会执行的过程 // 实际执行是&#xff1a;n个字符&#xff0c;递推n1后&#xff08;叶子节点&#xff…

张一鸣从创业之初到现在的231句话

1.人常会不自觉地记下对自己有利的部分&#xff0c;这是形成委屈的重要原因。 2.延迟满足感程度在不同量级的人是没法有效讨论问题的&#xff0c;因为他们愿意触探停留的深度不一样。 3.做不好的就别做了&#xff0c;要做就必须做到非常好。 4.当感到沟通困难的时候&#xf…

2025年1月23日-知道自己在哪儿,知道自己在路上

在哪里&#xff1f;在路上&#xff1f; 想写一写的时候&#xff0c;就突然想写一写。 一些事情&#xff0c;一些在路上的事情&#xff0c;一些知道自己在路上的事情。 元旦过后&#xff0c;市场一路阴跌&#xff1b;牛市多长阴&#xff0c;一根大阴线配合小反弹&#xff0c;…