FastApiAdmin 后端接口开发好了,前端管理界面怎么调用与显示?

😫 后端接口写好跑通了,但前端页面一片空白,菜单都找不到在哪加

上次我们把会议纪要的后端接口写好了,controller.py 里路由定义得清清楚楚,Swagger 文档里增删改查接口全部调试通过,心里美滋滋。

结果打开前端后台管理页面,左侧菜单里根本找不到"会议纪要"的入口。我愣了几分钟,刷新了几次页面,又重启了几遍服务,啥变化都没有。

后来才明白:FastapiAdmin 后端的接口是纯数据接口,前端是一个独立的 Vue3 工程,后端写完了 ≠ 前端能看到。你得手动配置菜单、写 API 请求层、开发 Vue 页面组件。这套流程我踩了一路的坑,今天就全部整理出来。

📌 本文能帮你解决什么

✅ 搞懂 FastapiAdmin 后端接口和前端页面之间的"连接逻辑"

✅ 手把手完成菜单配置、API 封装、页面开发的完整流程

✅ 避开菜单不显示、接口报 403、组件不渲染等高频翻车场景

🧭 主要内容脉络

前后端连接逻辑

➡️ 第1步:后端菜单配置

➡️ 第2步:前端 API 封装

➡️ 第3步:Vue 页面组件开发

➡️ 第4步:路由与权限联动

➡️ 常见翻车现场

1. 先把逻辑搞清楚:后端接口是怎么"变成"前端页面的?

FastapiAdmin 的前端基于 Vue3 + Vite5 + Pinia + Ant Design Vue ,它的菜单是动态生成的:用户登录后,前端调用接口获取该用户有权访问的菜单树,然后动态注册路由、渲染左侧导航栏。

所以整个链路是这样的:
🔹 ① 后端菜单配置:在后台管理界面中创建一条菜单记录,填上路由路径、组件路径、权限标识。

🔹 ② 前端 API 封装:在 frontend/src/api/ 下写一个请求模块,封装对后端接口的 HTTP 调用。

🔹 ③ 页面组件开发:写一个 Vue 页面,用 Ant Design Vue 的表格和弹窗实现增删改查的 UI。

🔹 ④ 路由与权限联动:确保菜单里的组件路径和前端路由配置一致,权限标识和接口的 Depends 一致。

你可能会问:"为什么不能自动生成?"其实 FastapiAdmin 确实内置了代码生成器,可以一键生成前后端代码。但自动生成的东西不一定完全符合你的需求,理解手动流程能让你在定制化时心里有底。

2. 第1步:在后台管理界面配置菜单

登录后台 → 左侧菜单找"平台管理" → 点击"菜单管理"。你会看到一个树形结构的菜单列表。

点击"新增",填以下信息:
📋 菜单名称:会议纪要

📋 菜单类型:菜单

📋 路由路径:/custom/meeting/

📋 组件路径:module_custom/meeting/index

📋 权限标识:custom:meeting:test

📋 图标:选一个合适的图标

📋 排序:自己定

保存后,如果非管理员用户使用,别忘了去"角色管理"里给当前角色分配这个新菜单的权限,否则你就算加了菜单也看不见。

这个坑我一脚踩进去过------菜单建好了,角色没分配,左侧导航栏就是不显示,试了半天才找到原因。

3. 第2步:在前端工程里封装 API 请求

打开前端目录 frontend/src/api/,FastapiAdmin 的惯例是每个业务模块一个请求文件 。我们在 api/ 下新建 module_custom/meeting.ts:

复制代码
import { request } from "@utils";

const API_PATH = "/custom/meeting";

const MeetingAPI = {
    getTest() {
        return request<ApiResponse>({
            url: `${API_PATH}/`,
            method: "get",
        })
    }
}

export default MeetingAPI

注意这里的 request 是项目自己封装的 axios 实例,已经帮你处理好了 baseURL、token 注入、错误拦截这些通用逻辑。你别自己再 new 一个 axios 出来,不然 token 不会自动带上,请求全报 401。

4. 第3步:开发 Vue 页面组件(重头戏)

在 frontend/src/views/ 下新建 module_custom/meeting/index.vue(路径要和菜单里填的组件路径对上!)。

这里我们先编写一个简单的字串响应,中通逻辑再进行后续功能添加:

复制代码
<script setup lang="ts">
import MeetingAPI from "@/api/module_custom/meeting";
import { ref } from "vue";

const info = ref("test");

onMounted(async () => {
  await MeetingAPI.getTest()
    .then((res) => {
      console.log(res.data);
      info.value = res.data["msg"];
    })
    .catch((err) => {
      console.log("出错啦!");
      console.log(err);
    });
});
</script>
<template>
  <p>{{ info }}</p>
</template>

后面有时间我们再研究下用 Ant Design Vue 的 a-table 做列表展示,用 a-modal 做新增/编辑弹窗。

5. 第4步:路由与权限的最后确认

页面写好之后,还有最后一道关卡:确保菜单里的路由路径和权限标识能对上。
🔹 菜单里填的 路由路径 /meeting ,必须和你页面文件的实际位置对应。FastapiAdmin 前端默认会动态注册路由,路径对不上就 404。

🔹 菜单里填的 权限标识 meeting:list ,必须和你后端 controller 里 Depends(AuthPermission(["meeting:list"])) 完全一致。哪怕多一个空格都会导致前端拿到 403,然后界面上啥也不显示------这个错我查了一整个下午。

🔹 配置完菜单后,退出登录重新登录一次。因为菜单权限是登录时获取的,不刷新的话新菜单永远不会出现。

6. 常见翻车现场:这些错误我替你趟了

🔴 菜单加了但左侧不显示:十有八九是没给当前角色分配权限,去角色管理里勾上。还有一个可能是没重新登录。

🔴 页面打开了但一片空白:打开浏览器控制台看报错。常见原因:组件路径拼错了、Vue 文件不存在、或者路由懒加载失败。

🔴 接口能访问但数据不显示 :检查后端返回的 JSON 结构是不是前端期望的。比如你后端直接 return 了一个列表,但前端期望的是 { data: { items: [], total: 0 } } 这种带分页信息的格式。

  1. 我的血泪总结

FastapiAdmin 后端的那个 controller,只是定义了"数据怎么存取"。但一个完整的后台功能,还需要菜单配置 + 前端 API 封装 + 页面组件开发 + 角色权限分配四个环节全部走通。

好在这套流程跑顺一次之后,后面再加任何模块都是复制粘贴改参数的事。官方也提供了代码生成器,熟悉了手动流程再用工具提效,心里会更有底。

如果你时间紧,直接用代码生成器一键生成前后端代码,也是个不错的选择------生成出来的文件结构和我们手动写的几乎一样,只是帮你省了敲键盘的时间。


💬 如果你也在用 FastapiAdmin 做前后端联调,卡在菜单显示或者接口对接上,留言说说你遇到的坑。点赞收藏加关注,我们继续深入学习探讨~

相关推荐
rayyy94 小时前
神经网络模型的外推性验证
pytorch·python·深度学习
长乐呀4 小时前
数据集获取与整理
python
清水白石0084 小时前
从脚本到系统:设计一个支持插件、限流、重试与监控的 Python 异步爬虫框架
网络·爬虫·python
deepin_sir4 小时前
02 - 第一个 Python 程序
开发语言·python
徐先生 @_@|||4 小时前
pycharm/IDEA + markdown + 图床(PicList)
ide·python·pycharm·intellij-idea
ZHW_AI课题组5 小时前
基于PCA与HOG特征融合的热轧钢带缺陷检测
人工智能·python·机器学习
MediaTea5 小时前
DL:扩散模型的基本原理与 PyTorch 实现
人工智能·pytorch·python·深度学习·机器学习
programhelp_5 小时前
Ramp OA 四关全过,CodeSignal OOD 完整复盘
linux·前端·python
Chasing__Dreams5 小时前
大模型应用开发--0--知识点
python