项目亮点 封装request请求模块
封装网络请求模块 统一管理和复用
在项目根目录的utils文件夹下 request模块更新
const http = axios.create({baseURL: 'http://geek.itheima.net/v1_0',timeout: 5000
})
定义根域名和超时时间
请求拦截器
请求发送之前拦截,做自定义的配置
// 添加请求拦截器
request.interceptors.request.use(config => {// if not login add tokenconst token = getToken()if (token) {config.headers.Authorization = `Bearer ${token}`}return config
})
将用户token携带进头部传给后端
响应拦截器
// 添加响应拦截器
request.interceptors.response.use((response)=> {// 2xx 范围内的状态码都会触发该函数。// 对响应数据做点什么return response.data}, (error)=> {if(error.response.status === 401){// 监听到401// 1.清除tokenremoveToken()router.navigate('/login')// 2.浏览器强制刷新 // window.location.reload(]9)}// 超出 2xx 范围的状态码都会触发该函数。// 对响应错误做点什么return Promise.reject(error)
})