二次封装axios,根据参数来实现多个请求多次拦截

二次封装axios,根据参数来实现多个请求多次拦截

1. 新建 axiosTool.js 文件,设置请求拦截和处理的逻辑

import Vue from 'vue'
import axios from 'axios'
//取消请求
let CancelToken = axios.CancelToken
//设置默认请求头,如果不需要可以取消这一步
axios.defaults.headers = {
    'X-Resquested-With': 'XMLHttpRequest'
}
//设置请求超时时间
axios.defaults.timeout = 10000
//开始请求设置,发起拦截处理
//config代表发起请求的参数实体
axios.interceptors.request.use(config => {
    //得到参数中的requestname字段,用于决定下次发起请求,取消相应的  相同字段的请求
    //post和get请求方式的不同,使用三木运算处理
    let requestName = config.method === 'post'?config.data.requestName :config.params.requestName
    //判断,如果这里拿到上一次的requestName,就取消上一次的请求
    if(requestName) {
        if(axios[requestName]&&axios[requestName].cancel){
            axios[requestName].cancel()
        }
        config.cancelToken = new CancelToken(c => {
            axios[requestName] = {}
            axios[requestName].cancel = c
        })
    }
    return config
}, error => {
    return Promise.reject(error)
})

//请求到结果的拦截处理
axios.interceptors.response.use(config => {
    //返回请求的正确结果
    return config
},error => {
    //错误的请求处理,这里根据后台返回的状态吗返回相应的信息
    if(error && error.response){
        switch (error.response.status){
            case 400:
            error.message = '错误请求'
            break
            case 401:
                error.message = '未授权,请重新登录'
                break
            case 403:
                error.message = '拒绝访问'
                break
            case 404:
                error.message = '请求错误,未找到该资源'
                break
            case 405:
                error.message = '请求方法未允许'
                break
            case 408:
                error.message = '请求超时'
                break
            case 500:
                error.message = '服务器端出错'
                break
            case 501:
                error.message = '网络未实现'
                break
            case 502:
                error.message = '网络错误'
                break
            case 503:
                error.message = '服务不可用'
                break
            case 504:
                error.message = '网络超时'
                break
            case 505:
                error.message = 'http版本不支持该请求'
                break
            default:
                error.message = `连接错误${error.response.status}`
        }
    }else{
        error.message='链接服务器失败'
    }
    return Promise.reject(error.message)
})

//将axios的post方法绑定到vue的实例上面
Vue.prototype.$post = function(url,params){
    return new Promise((resolve,reject) => {
        axios.post(url,params)
        .then(res => {
            resolve(res)
        }).catch(err => {
            reject(err)
        })
    })
}

//将axios的get方法绑定到vue的实力上面
Vue.prototype.$get = function(url,parmas){
    return new Promise((resolve,reject) => {
        axios.get(url,{params: params})
        .then(res => {
            resolve(res)
        }).catch(err =>{
            reject(err)
        })
    })
}

//请求示例
// requestName 为多余的参数 作为请求的标识,下次发起相同的请求,就会自动取消上一次还没有结束的请求
// 比如正常的请求参数只有一个 name: '123',但是这里我们需要额外再加上一个 requestName
/**
    this.$post(url, { name: '123', requestName: 'post_1' })
        .then(res => {
            console.log(`请求成功:${res}`)
        })
 */

export default axios

2.在main.js

import {axios} from './axiosTool'

3.在组件中使用

<script>
export default {
    name: 'page2',
    data () {
      return {
        msg: 'sssssssssssss'
      }
  },
  created(){
      this.showpost()
  },
  methods:{
      showpost(){
          this.$post('/api', {
            name: "王",
            requestName: 'name02'//这个参数必须传入,值随意
        }).then(res => {
            console.log(res)
            this.msg = res
        })
      }
  }
}
</script>

原文:https://dev.iviewui.com/articles/1031444597349421056

猜你喜欢

转载自blog.csdn.net/qq_39197547/article/details/81909041