axios拦截器用来在请求或响应被then
或catch
处理前拦截它们,也就是在发送请求之前和接收到响应之后做一些额外逻辑。例如token请求等
众所周知http请求有响应头和请求头,那么自然的,axios拦截器就可以对响应头和请求头进行一些额外的处理
请求头request
// 添加请求拦截器
axios.interceptors.request.use(function (config) {
// 在发送请求之前做些什么
return config;
}, function (error) {
// 对请求错误做些什么
return Promise.reject(error);
});
响应头response
// 添加响应拦截器
axios.interceptors.response.use(function (response) {
// 对响应数据做点什么
return response;
}, function (error) {
// 对响应错误做点什么
return Promise.reject(error);
});
一般来说(在webpack中),axios拦截器写在main.js中就好了,但这样会带来一个问题,在网页刷新的时候不会走main.js。拦截器不会被触发,也就是说我们需要再写一个js文件然后被main.js引入。
例如(http.js):
import Vue from 'vue'
import axios from 'axios'
Vue.use(axios);
// 添加请求拦截器
axios.interceptors.request.use(function (config) {
// 在发送请求之前做些什么
return config;
}, function (error) {
// 对请求错误做些什么
return Promise.reject(error);
});
// 添加响应拦截器
axios.interceptors.response.use(function (response) {
// 对响应数据做点什么
return response;
}, function (error) {
// 对响应错误做点什么
return Promise.reject(error);
});
export default axios;
在main.js中:
import axios from './http'
Vue.prototype.$axios = axios
这样就可以在刷新的时候也触发拦截器了
Comments | NOTHING