安装
pnpm add axios
封装
import axios from 'axios'
import { ElMessage } from 'element-plus'
const request = axios.create({
baseURL: import.meta.env.VITE_APP_BASE_API,
timeout: 5000,
})
request.interceptors.response.use(
(response) => {
return response.data
},
(error) => {
const requestUrl = error.response ? error.response.config.url : 'N/A'
let msg = ''
const status = error.response.status
switch (status) {
case 401:
msg = 'token过期'
break
case 403:
msg = '无权访问'
break
case 404:
msg = `404 - 请求地址错误 (请求路径: ${requestUrl})`
break
case 500:
msg = '服务器出现问题'
break
default:
msg = '无网络'
}
ElMessage({
type: 'error',
message: msg,
})
return Promise.reject(error)
},
)
export default request
使用
import request from '@/utils/request'
export const reqLogin = (data: loginFormData) => {
return request.post<any, loginResponseData>(API.LOGIN_URL, data)
}