总体思路(可以结合axios官方文档)

一、通常在src文件夹新建一个utils/request.js文件,对axios进行二次封装(记住先把axios安装了哦)
import axios from 'axios'//导入axios
import { useUserStore } from '@/stores'//导入vuex、pinia仓库,可根据需要可有可无
import router from '@/router' //导入路由,可根据需要可有可无
const baseURL = 'http://big-event-vue-api-t.itheima.net' //设置基础路径参数
//默认配置
const request = axios.create({
// TODO 1. 基础地址,超时时间
baseURL,
timeout: 10000
})
// 请求拦截器(根据需要自己设置)
request.interceptors.request.use(
(config) => {
// TODO 2. 携带token
const useStore = useUserStore()
if (useStore.token) {
config.headers.Authorization = useStore.token
}
return config
},
(err) => Promise.reject(err)
)
// 响应拦截器(跟据需要自己设置)
request.interceptors.response.use(
(res) => {
// TODO 4. 摘取核心响应数据
if (res.data.code === 0) {
return res
}