axios二次封装配置请求拦截器和响应拦截器

我们为什么要对axios进行二次封装?

因为我们可以使用请求拦截器在发送请求之前处理一些业务,使用响应拦截器在服务器数据返回后处理一些业务。

我们通常创建一个api文件夹,再创建一个request.js文件,用于存放重写后的axios。

javascript 复制代码
// 引入axios
import axios from "axios";

// 利用axios对象的create 方法去创建一个axios实例,我们可以对其进行配置
const requestObj = axios.create({
    // 基础路径:一般我们发送请求时都会出现api
    baseURL: "/api",
    // 请求超时的时间
    timeout: 5000
});

// 请求拦截器:在请求发送之前,请求拦截器检测到,也可以在请求发出去之前做一些事情
requestObj.interceptors.request.use((config) => {
    // config:配置对象,其中有headers请求头
    return config;
})

// 响应拦截器
// 有成功请求函数和失败回调函数
requestObj.interceptors.response.use((res) => {
    // 成功回调函数:直接返回请求的数据
    return res.data;
}, (error) => {
    // 失败回调函数:返回一个Promise对象
    return Promise.reject(new Error('faile'));
})

export default requestObj;
相关推荐
讯方洋哥2 分钟前
应用冷启动优化
前端·harmonyos
__万波__4 分钟前
二十三种设计模式(十三)--模板方法模式
java·设计模式·模板方法模式
动亦定4 分钟前
微服务中如何保证数据一致性?
java·数据库·微服务·架构
speedoooo6 分钟前
未来的App不再需要菜单栏?
前端·ui·容器·小程序·web app
王桑.9 分钟前
Spring中IoC的底层原理
java·后端·spring
Liii40315 分钟前
Java集合详细讲解
java·开发语言
落羽的落羽21 分钟前
【C++】哈希扩展——位图和布隆过滤器的介绍与实现
linux·服务器·开发语言·c++·人工智能·算法·机器学习
猿究院_xyz32 分钟前
微信小程序与echarts联动安卓真机测试出现黑色阴影
前端·javascript·微信小程序·小程序·echarts
fish_xk32 分钟前
类和对象(二)
开发语言·c++·算法
lly20240635 分钟前
Python 列表(List)详解
开发语言