当前位置: 首页 > 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.gsyq.cn/news/1604363.html

相关文章:

  • 如何完整恢复老旧iOS设备:5步快速降级与越狱教程
  • HarmonyOS技术精讲-应用间跳转:典型场景二——地图导航与位置服务
  • 当 leader 被隔离: etcd 网络分区深度分析
  • 从像素到光点:基于SSD1306 OLED的动态光源控制与传感应用
  • HarmonyOS技术精讲-应用间跳转:精确控制跳转目标(显式跳转)
  • 【Vid-Agent】长视频理解VideoTemp-o3框架
  • TI TAS2559智能功放评估板硬件解析与上手指南
  • 打破进口垄断!云克隆推出肠道七因子高通量检测全新方案
  • Grad-CAM实战:从理论到热力图生成
  • 【实战解析】从噪声到特征:ECG信号预处理与智能筛选全流程拆解
  • 拼多多运营整体框架(2026 最新精细化玩法)
  • 【无标题】实训平台基础软件基于自研Docker容器编排管理引擎,运用云原生和容 器技术构建训练环境
  • 正则表达式详解(C++20 )
  • 戴森球计划3000+工厂蓝图终极指南:从新手到专家的完整解决方案
  • Unity Mod Manager:轻松管理Unity游戏模组的终极指南
  • Docker--Docker引擎与镜像相关命令
  • 【infra之路】10-PagedAttention 与 KV Cache 管理
  • 3分钟掌握AI智能分层:Layerdivider让单图变多层的终极指南
  • 5分钟快速上手:diff-pdf - 免费开源的PDF差异检测神器
  • 基于SQL实现分组的文字排序聚合
  • 8-EnBoT-SORT:面向高密度热红外无人机的层次化融合关联追踪与伪样本生成方法
  • 高速接口静电防护:ESD器件选型与电容考量实战
  • 泛化管理化技术模板与泛型编程
  • GEO代理总部提供售后支持吗
  • Splunk Enterprise高危漏洞CVE-2024-36991深度剖析与复现指南
  • 如何在Kodi上免费搭建115网盘云端影院:终极观影解决方案
  • AXI DMA实战:从ZYNQ PS到PL的高效数据通路构建【Vivado设计】
  • 研究背景:解决视频世界模型的“长时漂移”问题
  • 软件设计的模块划分与接口定义
  • 最新量化初学四步走,概念代码回测模拟别混在一起