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;
posted @ 2024-05-11 11:10  Frommoon  阅读(14)  评论(0编辑  收藏  举报