- 从服务器拉取完整代码 - 按框架规范整理项目结构 - 配置 Drone CI 测试环境部署 - 包含后端(FastAPI)、前端(Vue3)、管理端 技术栈: Vue3 + TypeScript + FastAPI + MySQL
4.2 KiB
4.2 KiB
统计分析功能 - 快速测试指南
🎉 功能已完成
统计分析页面的所有硬编码数据已全部替换为真实数据库对接!
📋 完成清单
✅ 后端开发
- 创建统计服务层 (
app/services/statistics_service.py) - 创建6个RESTful API接口 (
app/api/v1/statistics.py) - 注册路由到主应用
✅ 前端开发
- 创建API客户端 (
src/api/statistics.ts) - 完全重写统计分析页面 (
src/views/analysis/Statistics.vue) - 实现科目和时间范围筛选联动
- 添加完整的加载、错误、空状态处理
✅ 文档更新
- 联调经验汇总已更新
- 实施总结文档已生成
🚀 快速测试
1. 启动后端 (Docker环境)
cd /Users/nongjun/Desktop/Ai公司/本地开发与测试
docker-compose -f docker-compose.dev.yml up -d
或者本地启动:
cd kaopeilian-backend
source venv/bin/activate
uvicorn app.main:app --reload --port 8000
2. 启动前端
cd kaopeilian-frontend
npm run dev
3. 访问统计分析页面
打开浏览器访问: http://localhost:5173/analysis/statistics
4. 测试API (可选)
cd kaopeilian-backend
source venv/bin/activate
python test_statistics_api.py
或使用curl:
# 获取关键指标
curl "http://localhost:8000/api/statistics/key-metrics?period=month"
# 获取成绩分布
curl "http://localhost:8000/api/statistics/score-distribution?period=month"
# 获取难度分析
curl "http://localhost:8000/api/statistics/difficulty-analysis?period=month"
🎯 测试要点
1. 基础功能
- 页面正常加载,显示加载动画
- 科目下拉显示真实课程列表
- 时间范围下拉有5个选项
- 关键指标卡片显示数值和环比
2. 图表展示
- 成绩分布饼图正确显示
- 难度分析雷达图正确显示
- 知识点掌握度柱状图正确显示
- 学习时长折线图正确显示
3. 筛选功能
- 选择不同科目,数据自动更新
- 选择不同时间范围,数据自动更新
- 所有图表和表格同步更新
4. 边界情况
- 新用户(无数据)显示空状态
- 网络错误时显示错误提示
- 可以点击"重新加载"按钮
5. 响应式
- 缩小浏览器窗口,布局自适应
- 图表自动调整大小
📊 功能说明
关键指标
- 学习效率: 正确题数 / 总题数
- 知识覆盖率: 已掌握知识点 / 总知识点
- 平均用时: 总考试时长 / 总题数
- 进步速度: 成绩环比增长率
图表展示
- 成绩分布: 优秀/良好/中等/及格/不及格的分布
- 难度分析: 不同难度题目的正确率
- 知识点掌握度: Top 6知识点的掌握情况
- 学习时长: 每日学习时长和练习时长
详细数据表格
- 按日期汇总的考试次数、平均分、学习时长、练习题数、正确率、进步指数
🔍 API文档
访问: http://localhost:8000/docs
查看所有统计分析API的完整文档和在线测试。
❓ 常见问题
Q1: 页面显示"暂无数据"?
A: 确保数据库中有考试记录。可以先进行一次考试,然后再查看统计。
Q2: API返回500错误?
A: 检查数据库连接,确保MySQL服务正常运行。
Q3: 图表不显示?
A: 打开浏览器控制台(F12),查看是否有JavaScript错误。
Q4: 科目下拉为空?
A: 确保数据库中有已发布的课程(status='published')。
📁 重要文件位置
后端
- 服务层:
/kaopeilian-backend/app/services/statistics_service.py - API路由:
/kaopeilian-backend/app/api/v1/statistics.py - 测试脚本:
/kaopeilian-backend/test_statistics_api.py
前端
- API客户端:
/kaopeilian-frontend/src/api/statistics.ts - 页面组件:
/kaopeilian-frontend/src/views/analysis/Statistics.vue
文档
- 联调经验:
/考培练系统规划/全链路联调/联调经验汇总.md - 实施总结:
/.cursor/plans/统计分析功能实施总结.md
📞 需要帮助?
如有问题,请查看:
- 浏览器控制台(F12) - 查看前端错误
- 后端日志 - 查看API错误
- 数据库日志 - 查看查询错误