2.7 KiB
2.7 KiB
任务交接简报:VR Tree API 实现
创建时间:2026-05-15 负责人:西莉雅(统筹),大头(产品决策)
目标
实现新 API /api/goods/tree,解决当前前端 O(n²) 重建层级的问题,同时消除座位模板数据冗余。
核心设计
扁平数据 + 查询管理器
扁平 SKU(spec_key 索引)
→ 查询管理器(按 group_by 聚合)
→ 层级树(叶节点含 template_key)+ 模板去重池 + 扁平 SKU 列表
→ 缓存(TTL=60s)
→ API 返回
模板去重原则
同一 venue + room + section 的座位图模板在所有场次下共享,只存一份,不按 session 重复。
前端交互(全程零额外 API 调用)
初始加载:GET /api/goods/tree → tree + seat_templates_flat + flat_inventory
用户选座:venue → session → room → section → 查 template_key → 查模板 → 渲染座位图
spec_key 前缀匹配:前端在 flat_inventory 里本地过滤
关键文件
| 文件 | 作用 |
|---|---|
docs/14_TREE_API_DESIGN.md |
完整设计文档(必读) |
docs/TASK_TREE_API_IMPLEMENTATION.md |
实施任务清单(执行依据) |
docs/15_FLAT_INVENTORY_QUERY_MANAGER.md |
方案对比与决策记录 |
service/SeatSkuService.php |
数据源(复用,不改) |
service/SeatMapService.php |
数据源(复用,不改) |
api/Goods.php |
新增 tree() 接口 |
技术要点
- spec_key 格式:
$vr-场次=X|$vr-场馆=X|$vr-演播室=X|$vr-分区=X|$vr-座位号=X(固定顺序,|连接) - template_key 格式:
venue_room_section(由后端生成,前端只引用) - group_by 参数:前端指定层级顺序,如
venue,session,room,section - 缓存失效:订单支付成功后同时清除 tree 缓存
不需要改动的内容
vr_seat_templates表结构vr_goods_config存储格式SeatSkuService::BatchGenerate()逻辑- 前端选座核心逻辑(只是数据源变了,渲染逻辑不变)
测试命令
curl "http://localhost:10000/api.php?s=plugins/index&pluginsname=vr_ticket&pluginscontrol=goods&pluginsaction=tree&goods_id=118&group_by=venue,session,room,section" \
-H "X-Requested-With: XMLHttpRequest"
验证:
meta.flat_count> 0(SKU 数量)meta.template_count> 0(模板数量,应 << flat_count)tree有正确的嵌套层级结构seat_templates_flat中每个模板只出现一次
如遇问题
- spec_key 格式不对:检查
SeatSkuService::makeSpecKey()的排序逻辑 - 模板去重不生效:检查 template_key 生成逻辑是否按 venue+room+section 组合
- 前端匹配失败:确认前端 spec_key 排序与后端一致