• axios拦截器配合element ui实现http请求的全局加载


    axios拦截器配合element ui实现http请求的全局加载

    96 
    辉夜真是太可爱啦 
    2019.04.29 13:26 字数 66 阅读 2评论 0

    首先,在main.js中引入axios以及Loading

    import {Loading} from 'element-ui'
    import axios from "axios";
    

    定义一个开启以及关闭的方法

    let loading;
    function startLoading() {    //使用Element loading-start 方法
      loading = Loading.service({
        lock: true,
        text: '拼命加载中...',
      })
    }
    function endLoading() {    //使用Element loading-close 方法
      loading.close()
    }
    

    在请求的时候开启菊花loading

    //请求数据拦截器
    axios.interceptors.request.use(request => {
      startLoading();
      return request
    }, err => {
      return Promise.reject(err);
    });
    

    在接收response的时候关闭菊花loading,并且对错误的状态码进行一定的处理

    //接收响应拦截器
    axios.interceptors.response.use(response => {
      endLoading();
      return response
    }, err => {
      if (err && err.response) {
        switch (err.response.status) {
          case 400: err.message = '请求错误(400)'; break;
          case 401: this.$router.push('/login'); break;
          case 403: err.message = '拒绝访问(403)'; break;
          case 404: err.message = '请求出错(404)'; break;
          case 408: err.message = '请求超时(408)'; break;
          case 500: err.message = '服务器错误(500)'; break;
          case 501: err.message = '服务未实现(501)'; break;
          case 502: err.message = '网络错误(502)'; break;
          case 503: err.message = '服务不可用(503)'; break;
          case 504: err.message = '网络超时(504)'; break;
          case 505: err.message = 'HTTP版本不受支持(505)'; break;
          default: err.message = `连接出错(${err.response.status})!`;
        }
      } else {
        err.message = '连接服务器失败!'
      }
      message.error(err.message);
      return Promise.reject(err);
    });
    

    小礼物走一走,来简书关注我

  • 相关阅读:
    Hadoop--Map/Reduce实现多表链接
    map/reduce实现 排序
    Hadoop-Map/Reduce实现实现倒排索引
    虚拟机之仅主机模式(HostOnly)链接外网设置
    hadoop家族之mahout安装
    SQLserver中的常量与变量、判断循环语句
    sqlserver中的数据转换与子查询
    SQLserver中常用的函数及实例
    sqlserver的增删改查
    SQLserver数据库基础
  • 原文地址:https://www.cnblogs.com/shaozhu520/p/10836779.html
Copyright © 2020-2023  润新知