zoukankan      html  css  js  c++  java
  • axios二次封装具有请求/响应拦截的http请求

    import axios from 'axios'
    import qs from 'qs'
    
    // 请求拦截
    axios.interceptors.request.use(config => {
      // 此处可以封装一些加载状态
      return config
    }, error => {
      return Promise.reject(error)
    })
    
    // 响应拦截
    axios.interceptors.response.use(response => {
      return response
    }, error => {
      return Promise.resolve(error.response)
    })
    
    function checkStatus (response) {
      // 此处可以封装一些加载状态
      // 如果http状态码正常,则直接返回数据
      if(response) {
        if (response.status === 200 || response.status === 304) {
          return response.data
          // 如果不需要除了data之外的数据,可以直接 return response.data
        } else if (response.status === 401) {
          location.href = '/login';
        } else {
          throw response.data
        }
      } else {
        throw {data:'网络错误'}
      }
      
    }
    
    // axios默认参数配置
    axios.defaults.baseURL = '/api/v0';
    axios.defaults.timeout = 10000;
    
    // restful API封装
    export default {
      post (url, data) {
        return axios({
          method: 'post',
          url,
          data: qs.stringify(data),
          headers: {
            'X-Requested-With': 'XMLHttpRequest',
            'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'
          }
        }).then(
          (res) => {
            return checkStatus(res)
          }
        )
      },
      get (url, params) {
        return axios({
          method: 'get',
          url,
          params, // get 请求时带的参数
          headers: {
            'X-Requested-With': 'XMLHttpRequest'
          }
        }).then(
          (res) => {
            return checkStatus(res)
          }
        )
      },
      del (url, params) {
        return axios({
          method: 'delete',
          url,
          params, // get 请求时带的参数
          headers: {
            'X-Requested-With': 'XMLHttpRequest'
          }
        }).then(
          (res) => {
            return checkStatus(res)
          }
        )
      }
    }
  • 相关阅读:
    SQL Server 2008 R2英文版安装图解
    浅析在C#里面抛出SAP里面自定义的异常信息
    JavaScript中的函数基础
    《冷眼看IT》读书笔记IT将成为服务行业
    JavaScript入门
    IT成为第五个服务业
    JavaScript中匿名函数的困惑
    自定义的html radio button的样式
    探索客户端JavaScript
    JavScript中的循环
  • 原文地址:https://www.cnblogs.com/zjxiang008/p/13737636.html
Copyright © 2011-2022 走看看