request.interceptors.response.use(function(response){},function(error){})后端返回结果code===400不经过response,直接跳到error。
当后端返回状态码为 400 时直接进入 error 回调而不经过 response 回调,这是因为 axios 默认会将状态码不在 200 - 299 范围内的响应视为错误。
解决
1. 修改 validateStatus 配置
你可以通过修改 axios 实例的 validateStatus 配置,来改变对成功状态码的判断逻辑。
import axios from 'axios';// 创建 axios 实例
const request = axios.create({// 修改 validateStatus 配置,允许 400 状态码进入 response 回调validateStatus: function (status) {return status >= 200 && status < 500; // 这里将成功状态码范围修改为 200 - 499}
});// 添加响应拦截器
request.interceptors.response.use(function (response) {// 处理响应数据if (response.data.code === 400) {// 处理 code 为 400 的情况console.log('后端返回 code 为 400');}return response;},function (error) {// 处理错误console.error('请求出错:', error);return Promise.reject(error);}
);export default request;
2. 在 error 回调中处理状态码 400
如果不想修改 validateStatus 配置,也可以在 error 回调中处理状态码为 400 的情况。
import axios from 'axios';// 创建 axios 实例
const request = axios.create();// 添加响应拦截器
request.interceptors.response.use(function (response) {// 处理成功响应return response;},function (error) {// 处理错误if (error.response && error.response.status === 400) {// 处理状态码为 400 的情况console.log('后端返回 code 为 400');// 可以在这里进行其他处理,如提示用户等}return Promise.reject(error);}
);export default request;
总结
修改 validateStatus 配置:适用于你希望将更多状态码视为成功响应的情况,这样可以让这些状态码的响应进入 response 回调进行统一处理。
在 error 回调中处理:适用于你只想对特定状态码(如 400)进行特殊处理,而不改变 axios 对成功状态码的默认判断逻辑。
你可以根据实际需求选择合适的解决办法。 在使用 axios(推测你使用的 request 是 axios 实例)时,当后端返回状态码为 400 时直接进入 error 回调而不经过 response 回调,这是因为 axios 默认会将状态码不在 200 - 299 范围内的响应视为错误。下面为你详细分析可能的原因及解决办法。