首先安装axios
npm i aixos
//进行axios的二次封装:使用请求和响应拦截器
import axios from 'axios'
import { ElMessage } from 'element-plus'
//利用axios对象的create方法创建axios实例
let request = axios.create({
baseURL:import.meta.env.VITE_APP_BASE_API,//基础路径
timeout:5000 //超时时间设置
})
//request实例添加请求拦截器
request.interceptors.request.use((config)=>{
//config配置对象有header请求头属性
//返回配置对象
return config
})
//响应拦截器
request.interceptors.response.use((response)=>{
//成功的回调,response是服务端返回的数据,在这里简化数据
return response.data
},error=>{
//失败的回调:处理http网络错误
//定义一个变量:存储网络错误信息
let message = ''
let status = error.response.status
switch(status){
case 401:
message = 'Token过期'
break
case 403:
message = '无权访问'
break
case 403:
message = '请求地址错误'
break
case 500:
message = '服务器出错'
break
default:
message = '网络出现问题'
break
}
//提示错误信息
ElMessage({
type:'error',
message
})
return Promise.reject(error)
})
//对外暴露
export default request