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