Axios理解+封装
本文对Axios进行了讲解,并实现了对axios的二次封装
问题
- 请求API使用什么工具?
回答
- Axios,它提供了一个简单而强大的 API 来处理 HTTP 请求。比如使用
axios.get()
方法发起一个 GET 请求,然后,使用 Promise 的then()
方法来处理成功的响应,通过response.data
可以获取到返回的数据。如果请求失败,我们使用catch()
方法来处理错误。
// 引入 Axios
import axios from 'axios';
// 发起 GET 请求
axios.get('/api/users')
.then(response => {
// 处理成功的响应
console.log(response.data);
})
.catch(error => {
// 处理错误
console.error(error);
});
axios二次封装
- 在我的项目中我会对axios进行二次封装并使用请求与响应拦截器,先创建一个 Axios 实例,可以传递包含实例的基础路径、超时时间等的配置对象。然后,为实例添加请求拦截器和与响应拦截器。(请求拦截器可以用来添加请求头、修改请求参数、进行身份验证等操作;响应拦截器对响应进行拦截和处理,我会在这个地方处理http网络错误的)
//进行axios二次封装:使用请求与响应拦截器
import axios from 'axios';
import { ElMessage } from "element-plus";
//引入用户相关的仓库
import useUserStore from '@/store/modules/user';
//第一步:利用axios对象的create方法,去创建axios案例(其他的配置:基础路径、超时的时间)
let request = axios.create({
//基础路径
baseURL: import.meta.env.VITE_APP_BASE_API,//基础路径上会携带/api
timeout: 5000//超时设置
});
//第二步:request实例添加请求与响应拦截器interceptors
//request 拦截器会在每个请求发送之前拦截:可以用来添加请求头、修改请求参数、进行身份验证等操作
request.interceptors.request.use((config) => {
//获取用户相关的小仓库,获取仓库内部的token,登录成功以后携带给服务器
let userStore=useUserStore();
if (userStore.token){
config.headers.token=userStore.token
}
//config配置对象,headers属性请求头,经常给服务器端携带公共参数
//返回配置对象
// config.headers.token='123'//请求头携带参数
return config;//不返回会报错
});
//第三步:响应拦截器
request.interceptors.response.use((response) => {
//成功回调
//简化数据
return response.data;
}, (error) => {
//失败的回调:处理http网络错误的
//定义一个变量:存储网络错误信息
let message = '';
//http状态码
let status = error.response.status;
switch (status) {
case 401:
message = "token过期"
break;
case 403:
message = "无权访问"
break;
case 404:
message = "请求地址错误"
break;
case 500:
message = "服务器出现问题"
break;
default:
message = "网络出现问题"
break;
}
//提示错误信息
ElMessage({
type: 'error',
message
});
return Promise.reject(error);
});
//对外暴露
export default request;