这是axios封装的代码:import Vue from "vue"; //导入axios import axios from "axios"; //创建axios的实例 const http = axios.create({ //baseURL baseURL: "http://localhost:9999/api", //请求超时时间 //timeout: 1000, //前端设置跨域 //设置可跨域的请求头格式,可以避免让后端增加@CrossOrigin注解 headers: { "Access-Control-Allow-Origin": "*", "Access-Control-Allow-Methods": "POST, GET, OPTIONS, PUT, DELETE", "Access-Control-Allow-Headers": "Content-Type, X-Auth-Token, Origin, Authorization", }, }); //设置X-Requested-With的请求头(非必须),可以根据实际框架使用或去除 //注意:此处的请求头,和上面的headers的请求头,二者是两码事,作用是不一样的,也不会相互冲突 http.defaults.headers.common["X-Requested-With"] = "XMLHttpRequest"; //请求拦截器 http.interceptors.request.use( //发送请求之前,做些什么... (config) => { return config; }, //请求错误时,做些什么... (error) => { return Promise.reject(error); } ); //响应拦截器 http.interceptors.response.use( (response) => { // 对响应数据做些什么 return response; }, (error) => { // 针对响应错误代码,做些什么... if (error.response) { //根据HTTP状态码,来进行处理 //其它状态码,直接在这里继续追加即可 switch (error.response.status) { case 401: //未登录,跳转到登录页 break; case 403: //没有权限,跳转到403页面 break; case 404: //请求的资源不存在,跳转到404页面 break; case 500: //服务器内部错误,跳转到500页面 break; default: //其他错误,弹出错误信息 Message.error( error.response.data.message || "服务器异常,请稍后再试!" ); break; } } else { //请求超时或者网络异常,弹出错误信息 Message.error("网络异常,请稍后再试!"); } return Promise.reject(error); } ); //向外共享axios的实例对象 export default http;然后,我发起请求错误后为啥不弹出弹框
时间: 2024-01-03 18:03:43 浏览: 105
你需要在响应拦截器的错误处理代码中,使用ElementUI的Message组件弹出错误信息。在你的Vue组件中引入Message组件:
```javascript
import { Message } from 'element-ui';
```
然后,在响应拦截器中使用Message组件弹出错误信息:
```javascript
http.interceptors.response.use(
response => {
// 对响应数据做些什么
return response;
},
error => {
// 针对响应错误代码,做些什么...
if (error.response) {
//根据HTTP状态码,来进行处理
//其它状态码,直接在这里继续追加即可
switch (error.response.status) {
case 401:
//未登录,跳转到登录页
break;
case 403:
//没有权限,跳转到403页面
break;
case 404:
//请求的资源不存在,跳转到404页面
break;
case 500:
//服务器内部错误,跳转到500页面
break;
default:
//其他错误,弹出错误信息
Message.error(
error.response.data.message || "服务器异常,请稍后再试!"
);
break;
}
} else {
//请求超时或者网络异常,弹出错误信息
Message.error("网络异常,请稍后再试!");
}
return Promise.reject(error);
}
);
```
在这个例子中,我们在响应拦截器的错误处理代码中使用了Message.error()方法,弹出了错误信息。其中`error.response.data.message`是错误信息,使用`Message.error()`方法可以在页面上弹出错误提示。
阅读全文