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;
相关推荐
编程大师哥几秒前
如何在C++中使用Redis的事务功能?
开发语言·c++·redis
向前V7 分钟前
Flutter for OpenHarmony 二维码扫描App实战 - 关于实现
开发语言·javascript·flutter
weixin_427771619 分钟前
Vite 与 Webpack 模块解析差异
前端·webpack·node.js
永远是我的最爱11 分钟前
基于ASP.NET的图书管理系统的设计与实现
前端·后端·sql·visual studio
广州华水科技19 分钟前
单北斗GNSS技术在变形监测中的应用及其位移监测优势解析
前端
惊讶的猫19 分钟前
nia500总结
java·spring·mybatis
钟离墨笺20 分钟前
Go语言-->interfance{}赋值的陷阱
开发语言·后端·golang
刘晓倩24 分钟前
Python内置函数-hasattr()
前端·javascript·python
逆境清醒27 分钟前
Python中的常量
开发语言·python·青少年编程
aini_lovee30 分钟前
基于MATLAB的DC-DC变换器设计与实现(Buck/Boost/Buck-Boost)
开发语言·matlab