axios接口请求封装
一、通常在src文件夹新建一个utils/request.js文件,对axios进行二次封装(记住先把axios安装了哦)二、在src文件夹新建一个api文件夹,在该文件夹写业务相关的请求(这里是api/user.js)三、页面中调用(有参数就传递相应参数)
·
总体思路(可以结合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
}
// TODO 3. 处理业务失败
// 处理业务失败, 给错误提示,抛出错误
ElMessage.error(res.data.message || '服务异常')
return Promise.reject(res.data)
},
(err) => {
// TODO 5. 处理401错误
// 错误的特殊情况 => 401 权限不足 或 token 过期 => 拦截到登录
if (err.response?.status === 401) {
router.push('/login')
}
// 错误的默认情况 => 只要给提示
ElMessage.error(err.response.data.message || '服务异常')
return Promise.reject(err)
}
)
export default request //导出二次封装的axios
export { baseURL } //导出基础路径
二、在src文件夹新建一个api文件夹,在该文件夹写业务相关的请求(这里是api/user.js)
import request from '@/utils/request' //导入二次封装的axios
// 下面封装我们的接口(这里面封装的是用户信息的相关请求)
// 注册接口
export const userRegisterService = ({ username, password, repassword }) => {
return request.post('/api/reg', { username, password, repassword })
}
// 登录接口
export const userLoginService = ({ username, password }) =>
request.post('api/login', { username, password })
// 获取用户的基本信息
export const userGetInfoService = () => request.get('my/userinfo')
// 修改用户信息
export const userUpdateInfoService = ({ id, nickname, email }) =>
request.put('my/userinfo', { id, nickname, email })
// 更新用户头像
export const userUpdateAvatarService = (avatar) =>
request.patch('my/update/avatar', { avatar })
// 更新用户密码
export const userUpdatePasswordService = ({ old_pwd, new_pwd, re_pwd }) =>
request.patch('/my/updatePwd', { old_pwd, new_pwd, re_pwd })
三、页面中调用(有参数就传递相应参数)
const register = async () => { //点击注册事件
await form.value.validate() //表单验证
await userRegisterService(formModel.value) //调用注册接口并传参
ElMessage.success('注册成功')
isRegister.value = false
}
更多推荐
已为社区贡献2条内容
所有评论(0)