当前位置: 首页 > news >正文

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

本文能帮你解决什么

✅ 搞懂 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 } } 这种带分页信息的格式。

7. 我的血泪总结

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

好在这套流程跑顺一次之后,后面再加任何模块都是复制粘贴改参数的事。官方

http://www.jsqmd.com/news/1092405/

相关文章:

  • 还在愁毕业论文写不完?9款AI论文网站一键生成逻辑连贯初稿!
  • 从LC谐振到ADC采样:OPA4377运放电路在电磁信号处理中的核心作用
  • 革命性Beat Saber一站式管理方案:BSManager深度解析与实战指南
  • USB-I2C/GPIO适配器EVM硬件解析与实战调试指南
  • ChatGPT Plus用户流失率骤升23%的背后:不是价格问题,而是这1个被忽略的免费替代路径(企业级实测可用)
  • Python构建XSS检测系统:从原理到实践的动态验证与载荷变异
  • Moneta Markets亿汇:“通胀压力扰动科技资产”
  • VMPDump:如何快速掌握逆向工程中的动态脱壳与导入修复技术
  • 如何完整恢复老旧iOS设备:5步快速降级与越狱教程
  • 近期零基础学量化,先让 AI 帮你整理表达
  • 肿瘤标志物联合检测的科研进阶工具——多因子检测试剂盒
  • 如何快速解决Windows驱动签名验证问题:DSEFix完整使用指南
  • 打破进口垄断!云克隆推出肠道七因子高通量检测全新方案
  • TI TAS2559智能功放评估板硬件解析与上手指南
  • Java毕设项目:基于 Spring Boot 的电影评价与购票联动系统 影院票务数据统计与订单管理系统设计 (源码+文档,讲解、调试运行,定制等)
  • HarmonyOS技术精讲-应用间跳转:精确控制跳转目标(显式跳转)
  • 【Vid-Agent】长视频理解VideoTemp-o3框架
  • 训练 = 一个反复打分与改作业的循环
  • 从像素到光点:基于SSD1306 OLED的动态光源控制与传感应用
  • HarmonyOS技术精讲-应用间跳转:典型场景二——地图导航与位置服务
  • 当 leader 被隔离: etcd 网络分区深度分析
  • 从一个 “笨办法“ 说起
  • # Rocky Linux 9.5 搭建 Kafka + ELK 完整日志平台技术文档
  • 番外篇 F05:电机控制与PID调节实战《电机控制中的PID调节:位置式/增量式算法解析与使用场景全攻略》
  • 拼多多运营整体框架(2026 最新精细化玩法)
  • 【无标题】实训平台基础软件基于自研Docker容器编排管理引擎,运用云原生和容 器技术构建训练环境
  • 【实战解析】从噪声到特征:ECG信号预处理与智能筛选全流程拆解
  • 5大架构设计原则:深入剖析React Icons开源项目架构
  • 第86题 2026年国家级科研痛点——碳化硅(SiC)单晶衬底缺陷控制与扩径技术
  • MSPM0微控制器GPAMP与VREF模块:构建高精度模拟信号链的实战指南