1.在scr文件夹下创建api文件夹,api文件夹中专门用来书写需要向服务器发送的请求
2.在api文件夹下创建requests.js文件,其中进行axios的二次封装,详细备注见代码
// 对axios进行二次封装
import store from '@/store'
import axios from 'axios'
// 1.利用axios对象方法 create 去创建一个axios实例
// 2.request就是axios 只不过可以稍微配置一下
let requests = axios.create({
// 配置对象
// 基础路径:发送请求时自动在端口号后面添加基础路径内容
baseURL:'/api',
// 代表请求超时的时间
timeout:5000,
})
// 请求拦截器:在发送请求之前 请求拦截器可以检测到,在请求发送出去之前做一些事情
requests.interceptors.request.use((config)=>{
// config:配置对象 对象里面有一个很重要的属性:headers请求头
// 配置请求头
if(store.state.user.token){
config.headers.token = store.state.user.token
}
return config
})
// 响应拦截器
requests.interceptors.response.use((res)=>{
// 成功的回调函数:服务器返回数据之后,响应拦截器可以检测到,并做一些事情
return res.data
},(error)=>{
// 失败的回调函数
return Promise.reject(new Error(&#