zoukankan      html  css  js  c++  java
  • vue之element-ui设置全局弹出框

    这样的需求,在主要功能完成后,需要进行交互效果的完善,需要给请求api的时候添加一个加载中的一个弹出框。但是每个页面每个页面过的话,会很费时间和精力,这里我们可以采用element-ui中的服务式弹出框设置
    如下:
    封装的api.js文件:
    import axios from 'axios'
    import {Message,Loading} from 'element-ui'
    import router from '../router'
     
    //  请求拦截
    axios.interceptors.request.use(config=> {
      Loading.service({text:"Loading..."});
      return config;
    }, err=> {
      Message.error({message: '请求超时!'});
      return Promise.resolve(err);
    })
    //  响应拦截
    axios.interceptors.response.use(res=> {
      Loading.service().close();
        if (res.data.code == 200) {
          return res.data.result;
        } else if (res.data.code == 401) {
          router.push('/login')
          return Promise.reject(res);
        }
        return Promise.reject(res);
      }, err=> {
      Loading.service().close();
      if (err.response.status == 504||err.response.status == 404) {
          Message.error({message: '服务器被吃了⊙﹏⊙∥'});
        } else if (err.response.status == 403) {
          Message.error({message: '权限不足,请联系管理员!'});
        } else {
          Message.error({message: '未知错误'});
        }
        return Promise.reject(err);
    })
     
    let base = '';
    export const postRequest = (url, params) => {
      return axios({
        method: 'post',
        url: `${base}${url}`,
        data: params,
        transformRequest: [function (data) {
          let ret = ''
          for (let it in data) {
            ret += encodeURIComponent(it) + '=' + encodeURIComponent(data[it]) + '&'
          }
          loadingInstance.close();
          return ret
        }],
        headers: {
          'Content-Type': 'application/x-www-form-urlencoded'
        }
      });
    }
    export const getRequest = (url,data='') => {
      return axios({
        method: 'get',
        params: data,
        url: `${base}${url}`
      });
    } 
  • 相关阅读:
    DRP-ThreadLocal简单的理解
    Android开源项目SlidingMenu本学习笔记(两)
    [RxJS] Displaying Initial Data with StartWith
    [RxJS] Updating Data with Scan
    [RxJS] Stopping a Stream with TakeUntil
    [RxJS] Reactive Programming
    [RxJS] Reactive Programming
    [RxJS] Reactive Programming
    [RxJS] Starting a Stream with SwitchMap & switchMapTo
    [RxJS] Reactive Programming
  • 原文地址:https://www.cnblogs.com/bgwhite/p/9792461.html
Copyright © 2011-2022 走看看