
二次封装axios,根据参数来实现多个请求多次拦截
1. 新建 axiosTool.js 文件,设置请求拦截和处理的逻辑
import Vue from 'vue'
import axios from 'axios'
//取消请求
let CancelToken = axios.CancelToken
//设置默认请求头,如果不需要可以取消这一步
axios.defaults.headers = {
'X-Requested-With': 'XMLHttpRequest'
}
// 请求超时的时间限制
axios.defaults.timeout = 20000
// 开始设置请求 发起的拦截处理
// config 代表发起请求的参数的实体
axios.interceptors.request.use(config => {
// 得到参数中的 requestName 字段,用于决定下次发起请求,取消对应的 相同字段的请求
// 如果没有 requestName 就默认添加一个 不同的时间戳
let requestName
if(config.method === 'post'){
if(config.data && config.data.requestName){
requestName = config.data.requestName
}else{
requestName = new Date().getTime()
}
}else{
if(config.params && config.params.requestName){
requestName = config.params.requestName
}else{
requestName = new Date().getTime()
}
}
// 判断,如果这里拿到的参数中的 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 => {
// 错误的请求结果处理,这里的代码根据后台的状态码来决定错误的2. 再 main.js 中引入该文件
import { axios } from './static/js/axiosTool'3. 在组件中直接使用即可
this.$post(this.url2, {
name: "王",
docType: "pson",
requestName: 'name02'
}).then(res => {
console.log(res)
})
this.$get(this.url, {
name: "李",
requestName: 'name01'
}).then(res => {
console.log(res)
})4. 效果如图:

总结
以上所述是小编给大家介绍的vue interceptor 使用教程实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
