2-vue中Axios封装请求

Posted 孤芳不自赏!

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了2-vue中Axios封装请求相关的知识,希望对你有一定的参考价值。

import axios from \'axios\'
import {Message} from \'element-ui\'
axios.interceptors.request.use(config => {
  return config;
}, err => {
  Message.error({message: \'请求超时!\'});
  // return Promise.resolve(err);
})
axios.interceptors.response.use(data => {
  if (data.status && data.status == 200 && data.data.status == 500) {
    Message.error({message: data.data.msg});
    return;
  }
  if (data.data.msg) {
    Message.success({message: data.data.msg});
  }
  return data;
}, err => {
  if (err.response.status == 504 || err.response.status == 404) {
    Message.error({message: \'服务器被吃了⊙﹏⊙∥\'});
  } else if (err.response.status == 403) {
    Message.error({message: \'权限不足,请联系管理员!\'});
  } else if (err.response.status == 401) {
    Message.error({message: err.response.data.msg});
  } else {
    if (err.response.data.msg) {
      Message.error({message: err.response.data.msg});
    }else{
      Message.error({message: \'未知错误!\'});
    }
  }
  // return Promise.resolve(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]) + \'&\'
      }
      return ret
    }],
    headers: {
      \'Content-Type\': \'application/x-www-form-urlencoded\'
    }
  });
}
export const uploadFileRequest = (url, params) => {
  return axios({
    method: \'post\',
    url: `${base}${url}`,
    data: params,
    headers: {
      \'Content-Type\': \'multipart/form-data\'
    }
  });
}
export const putRequest = (url, params) => {
  return axios({
    method: \'put\',
    url: `${base}${url}`,
    data: params,
    transformRequest: [function (data) {
      let ret = \'\'
      for (let it in data) {
        ret += encodeURIComponent(it) + \'=\' + encodeURIComponent(data[it]) + \'&\'
      }
      return ret
    }],
    headers: {
      \'Content-Type\': \'application/x-www-form-urlencoded\'
    }
  });
}
export const deleteRequest = (url) => {
  return axios({
    method: \'delete\',
    url: `${base}${url}`
  });
}
export const getRequest = (url) => {
  return axios({
    method: \'get\',
    url: `${base}${url}`
  });
}

使用请求的封装

以上是关于2-vue中Axios封装请求的主要内容,如果未能解决你的问题,请参考以下文章

VSCode自定义代码片段14——Vue的axios网络请求封装

2-vue中Axios封装请求

基于Vue+Less+axios封装+ElementUI搭建项目底层支撑实战

回归 | js实用代码片段的封装与总结(持续更新中...)

vue中axios请求成功了如何把数据渲染到页面上?

axios 是如何封装 HTTP 请求的