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'