axios结合Promise设置"请求"和"响应"拦截器取消请求

// 获取CancelToken
const CancelToken = axios.CancelToken;
const source = CancelToken.source();

请求拦截

// http request 拦截器);
axios.interceptors.request.use(
  (config) => {
    // 全局添加cancelToken
    newConfig.cancelToken = source.token;
    return newConfig;
  },
  (err) => {
    const error = err;
    return Promise.reject(error);
  },
);

响应拦截

// http response 拦截器
axios.interceptors.response.use((response) => {
  const code = response.data.code;
  if (code == '002') {
    // 某个请求的响应满足特定条件的情况下,取消其他正在进行的请求
    source.cancel();
  }
  return Promise.resolve(response.data);
}, (error) => {
  if (axios.isCancel(error)) { // 取消请求的情况下,终端Promise调用链
    return new Promise(() => {});
  } else {
    return Promise.reject(error);
  }
});

你可能感兴趣的:(axios结合Promise设置"请求"和"响应"拦截器取消请求)