二次封装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>