封装 axios 方法

  1. 首先在 api 文件里面创建文件
    axio.js

    import axios from 'axios' // 首先引入 axios
    import { Message } from 'element-ui'
    
    const service = axios.create({
      baseURL: window.PLATFROM_CONFIG.tokenUrl, // 请求地址
      timeout: 60000, // 请求超时时间
      method: 'post' // 请求方式
    })
    
    service.interceptors.request.use( // 请求拦截器
      config => {
        let token = localStorage.getItem('token');
        if (U.notEmpty(token)) { // 如果有 token 为请求头添加 token
            config.headers['Authorization'] = "Bearer " + token;
        }
        return config
      },
      error => { // 错误处理
        return Promise.reject(error)
      }
    )
    
    service.interceptors.response.use( // 响应拦截器
      response=>{
        console.log('response =>',response)
        if(response.data.returnCode !== 1) { // 判断返回的code码做处理
          localStorage.removeItem("token");
          window.location.href =
            window.PLATFROM_CONFIG.ssoUrl +
            "/login?service=" +
            encodeURI(window.PLATFROM_CONFIG.heoUrl);
        }
        return response.data // return 返回的值
      },
    
      error=>{ // 错误处理
        Message({
          message: error.message,
          type: 'error',
          duration: 2000
        })
        return Promise.reject(error)
      }
    )
    
    export default service
    
  2. 然后在 mian.js 中挂载

    import request from '@/api/axio' // 引入刚刚封装的拦截器
    
    const api = Vue => { // 封装
     Object.defineProperties(Vue.prototype, {
       $api: {
         get() {
           return {
             post2: async (url) => {
               return new Promise((resolve, reject) => {
                 requestToken({url, method: 'post'}).then(res => {
                   U.unloading();  // 加载状态
                   return resolve(res); // 返回结果
                 }).catch(err => {
                   U.unloading();
                   reject(err) // 抛出错误
                 })
               })
              }
            }
          }
        }
      })
    }
    Vue.use(api) // 挂载
    
  3. 使用

    this.$api.post2('/xx/xxx').then(res => {
    }).catch(err => {})
    // ----或者------
    async doLogin() {
      try {
       const res = await this.$api.post2('/xx/xxx')
      } catch (error) {
      }
    },
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值