axios 拦截器的使用

发布于 2020-08-11  134 次阅读


axios 拦截器用来在请求或响应被 thencatch 处理前拦截它们,也就是在发送请求之前和接收到响应之后做一些额外逻辑。例如 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

这样就可以在刷新的时候也触发拦截器了