总体思路(可以结合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
}

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐