vue axios封装

今天童鞋问问axios怎么封装,我把自己封装的给贴上来。其中也有参考百度的。
我习惯在src目录下创建一个libs文件,然后在libs文件下创建axios.js.

// axios.js
import axios from "axios";
import { message } from "ant-design-vue"; // 这里是引用了一个公共的弹框

class HttpRequest {
  constructor(baseUrl = baseURL) {
    this.baseUrl = baseUrl;
    this.queue = {};
  }
  getInsideConfig() {
    return {
      baseURL: this.baseUrl
    };
  }
  destroy(url) {
    delete this.queue[url];
    if (!Object.keys(this.queue).length) {
      // Spin.hide()
    }
  }
  interceptors(instance, url) {
    // 请求拦截
    instance.interceptors.request.use(
      config => {
        // 添加全局的loading...
        if (!Object.keys(this.queue).length) {
          // Spin.show() // 不建议开启,因为界面不友好
        }
        this.queue[url] = true;
        return config;
      },
      error => {
        return Promise.reject(error);
      }
    );
    // 响应拦截
    instance.interceptors.response.use(
      res => {
        this.destroy(url);
        const { data, status } = res;
        return { data, status };
      },
      error => {
        this.destroy(url);
        let errorInfo = error.response;
        if (!errorInfo) {
          const {
            request: { statusText, status },
            config
          } = JSON.parse(JSON.stringify(error));
          errorInfo = {
            statusText,
            status,
            request: { responseURL: config.url }
          };
        }
        this.addErrorLog(errorInfo);
        return Promise.reject(error);
      }
    );
  }
  addErrorLog(err) {
    // console.log(err);
    const { status } = err;
    switch (status) {
      case 510:
        // console.log(message);
        message.error("登录失效,请重新登录");
        break;
      case 500:
        message.error(err.data);
        break;
      case 404:
        err.data.message === "No message available"
          ? message.error("请求错误")
          : message.error(err.data.message);
        break;
      default:
        message.error(err.data);
    }
  }
  request(options) {
    const instance = axios.create();
    options = Object.assign(this.getInsideConfig(options), options);
    this.interceptors(instance, options.url);
    return instance(options);
  }
}
export default HttpRequest;

然后在axios.js 同级 创建api.request.js

// api.request.js
import HttpRequest from "./axios";
// 这里写的是请求路径的ip或者域名
const baseUrl =
  process.env.NODE_ENV === "development"
    ? "" : window.location.origin + window.location.pathname;
const axios = new HttpRequest(baseUrl);
export default axios;

以上就是 axios 的封装了。接下来看一下是怎么使用的
libs 文件同级创建api文件夹,api下放置各个模块的接口js文件,直接看文件内如何使用

import axios from "@/libs/api.request";

export const centerMesList = () => {
   return axios.request({
         url: "api/v1/board/getMesList",
         methods: "get"
   });
};

然后在调用接口的页面直接引用

import { centerMesList, centerOeeList } from "@/api/board";
// 写到方法中
centerMesList().then(res => {
        const { status, data } = res;
        if (status === 200) {
          const { code, error, result } = data;
          if (code === 200) {
          } else {
            this.$message.error(error);
          }
        } else {
          this.$message.error("请求异常");
        }
      });


©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1.安装axios 2.新建一个axios.js文件,对axios进行封装 3.api.js(api的统一管理,模...
    w_wx_x阅读 352评论 0 0
  • 1,在src中新建request 文件夹,文件夹中包含api.js 和http.js api.js 中的代码如下:...
    一叶孤舟1990阅读 392评论 0 0
  • 为什么要对Axios进行封装 通常我们的项目会越做越大,页面也会越来越多,如果页面非常的少,直接用axios也没有...
    Guyere阅读 1,732评论 0 0
  • vue脚手架中,全局封装axios,让使用过程中更方便,更加容易管理各种api接口 一、axios封装——http...
    coderluojz阅读 329评论 0 2
  • 公司项目要求用H5写 作为一个iOS菜鸟搞起来啊,首先是搭建项目框架,项目框架直接用vue-cli搭建好,接下来是...
    千里111阅读 1,334评论 0 3