axios参数来拦截重复请求

有些时候,用户可能会重复请求数据,造成不必要的浪费,所以很有必要拦截重复的请求。

新建一个axios.js文件

import Vue from 'vue'
import axios from 'axios'
Vue.prototype.$ajax= axios
//取消请求
let CancelToken = axios.CancelToken
//设置默认请求头,如果不需要可以取消这一步
axios.defaults.headers = {
    'X-Resquested-With': 'XMLHttpRequest'
}
//设置请求超时时间
axios.defaults.timeout = 10000
axios.defaults.withCredentials = true;
//开始请求设置,发起拦截处理
//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)
})
 
//请求示例
// requestName 为多余的参数 作为请求的标识,下次发起相同的请求,就会自动取消上一次还没有结束的请求
// 比如正常的请求参数只有一个 name: '123',但是这里我们需要额外再加上一个 requestName
/**
    this.$ajax.post(url, { name: '123', requestName: 'post_1' })
        .then(res => {
            console.log(`请求成功:${res}`)
        })
 */
 
export default axios

main.js中调用

import axios from 'axios.js'

添加新评论