基于axios的三次封装

108 阅读1分钟

先创建一个api文件夹

再在里面创建一个http.js 或jsx

引入axios 配置基准地址 请求拦截和响应拦截 最后导出

import axios from "axios";

const instance = axios.create({
  baseURL: "https://www.lexuemiao.com/api/app/",
  timeout: 1000,
});

// 添加请求拦截器
instance.interceptors.request.use(
  function (config) {
    // 在发送请求之前做些什么
    return config;
  },
  function (error) {
    // 对请求错误做些什么
    return Promise.reject(error);
  }
);

// 添加响应拦截器
instance.interceptors.response.use(
  function (response) {
    // 2xx 范围内的状态码都会触发该函数。
    // 对响应数据做点什么
    return response;
  },
  function (error) {
    // 超出 2xx 范围的状态码都会触发该函数。
    // 对响应错误做点什么
    return Promise.reject(error);
  }
);

export default instance;

再封装一个请求方式 request.js 引入基准地址那个方法

import instance from "./http";

function request({ method, data, url, params }) {
  return instance({
    method,
    url,
    data,
    params,
  });
}

export default request;

最后再封装一个api.js统一管理我们的数据

import request from "./request";

export const list = () =>
  request({ method: "GET", url: "home/getFirstClassify" });