axios统一封装规范管理

新建/api/

1.新建统一处理文件/api/axios.ts

javascript 复制代码
import axios from "axios"

const http = axios.create({
  baseURL: import.meta.env.VITE_API_BASE_URL, // 从环境变量读取
  timeout: 10000,
});

// 请求拦截器(如添加 Token)
http.interceptors.request.use((config) => {
  const token = localStorage.getItem("token");
  if (token) {
    config.headers.Authorization = `Bearer ${token}`;
  }
  return config;
});

// 响应拦截器(统一处理错误和返回数据)
http.interceptors.response.use(
  (response) => {
    // 如果后端返回 { code, data, message } 格式
    if (response.data.code !== 200) {
      return Promise.reject(response.data.message); // 业务错误
    }
    return response.data.data; // 直接返回有效数据
  },
  (error) => {
    // HTTP 错误(如 401、404、500)
    const errorMessage = error.response?.data?.message || error.message;
    console.error("API Error:", errorMessage);
    return Promise.reject(errorMessage);
  }
);

export default http;

2.其他api:/api/user.ts

javascript 复制代码
// src/api/user.ts
import http from "./axios";

export const login = (data: { username: string; password: string }) => {
  return http.post("/auth/login", data);
};

export const getUserInfo = (userId: number) => {
  return http.get(`/user/${userId}`);
};
javascript 复制代码
import http from "./axios";

export const getProductList = (params: { page: number; size: number }) => {
  return http.get("/products", { params });
};

3.在组件中使用

css 复制代码
<script setup>
import { getUserInfo } from "@/api/user";
import { getProductList } from "@/api/product";

const fetchData = async () => {
  try {
    const user = await getUserInfo(1);
    const products = await getProductList({ page: 1, size: 10 });
  } catch (error) {
    console.error("请求失败:", error);
  }
};
</script>
相关推荐
知识分享小能手2 小时前
uni-app 入门学习教程,从入门到精通,uni-app基础扩展 —— 详细知识点与案例(3)
vue.js·学习·ui·微信小程序·小程序·uni-app·编程
MC丶科4 小时前
【SpringBoot 快速上手实战系列】5 分钟用 Spring Boot 搭建一个用户管理系统(含前后端分离)!新手也能一次跑通!
java·vue.js·spring boot·后端
lijun_xiao20096 小时前
前端最新Vue2+Vue3基础入门到实战项目全套教程
前端
90后的晨仔6 小时前
Pinia 状态管理原理与实战全解析
前端·vue.js
杰克尼6 小时前
JavaWeb_p165部门管理
java·开发语言·前端
90后的晨仔6 小时前
Vue3 状态管理完全指南:从响应式 API 到 Pinia
前端·vue.js
90后的晨仔6 小时前
Vue 内置组件全解析:提升开发效率的五大神器
前端·vue.js
我胡为喜呀7 小时前
Vue3 中的 watch 和 watchEffect:如何优雅地监听数据变化
前端·javascript·vue.js
我登哥MVP7 小时前
Ajax 详解
java·前端·ajax·javaweb
非凡ghost7 小时前
Typora(跨平台MarkDown编辑器) v1.12.2 中文绿色版
前端·windows·智能手机·编辑器·软件需求