tansci/.claude/skills/fa-page-optimizer/SKILL.md
xuewuerduo f468d532b1 feat: 初始化tansci资产管理项目
包含以下模块:
- antdv-next-admin: Vue 3 + TypeScript + Ant Design Vue 管理后台
  - 设备/许可证/配件/耗材 CRUD 管理页面
  - 基础数据管理 (分类/位置/制造商/型号/供应商)
  - 业务管理 (故障报修/盘点/资产分配/资产申请/交易记录)
  - 下拉选项改造 (ID输入框 → 搜索下拉选择)
  - 资产状态字典化 (接入sys_dict系统)
  - 界面文案优化 (设备→资产, 在库/在用/维修中/已报废)
  - 修复 console 警告 (popupClassName, 重复组件注册)
- our-itam: Java Spring Boot + magic-api 后端服务
- fantastic-admin: 前端底层框架 (pnpm monorepo)
- ciyo-itasset: CIYO 资产模块
- magic-script-skill: Claude Code skill 定义
- .claude: 对话历史记录

Co-Authored-By: Claude Code <noreply@anthropic.com>
2026-05-17 21:41:22 +08:00

3.0 KiB
Raw Blame History

name description
fa-page-optimizer 优化 Vue 页面,用 Fantastic-admin 框架内建组件packages/components/)替换自定义实现和原生 HTML。当用户说'帮我优化这个页面'、'把这些原生 HTML 换成框架组件'、'用 FaCard/FaModal/FaButton 重构一下'、'这个页面太乱了'、'统一一下 UI 风格'、'用内建组件替换自定义弹窗/分页/加载',即使用户只是说'看看这个页面能不能改进'也应触发此技能。

页面优化器

利用 Fantastic-admin 的 70+ 内建组件优化 Vue 页面,用框架组件替换自定义实现,减少重复代码,保持 UI 一致性。

第一步:确认工作区(必须阻塞等待用户回复)

本项目是 monorepo 架构,apps/ 目录下存放各应用。在执行任何文件读写操作之前,必须先确认目标应用:

  1. 执行 ls apps/ 列出所有可用应用
  2. 立即向用户提问,明确询问要优化哪个应用中的页面,并停止等待回复
  3. 收到用户明确回复后,才能继续后续步骤

严格规则:如果用户没有在请求中明确说明目标应用(例如"在 example 应用中"、"apps/core"),则必须提问,不得自行猜测或默认选择任何应用。

确认后,后续所有页面路径均在 apps/<app>/src/views/ 下。

优化工作流

步骤 1: 分析页面,识别替换机会

读取目标页面,找出三类可优化点:

  • 原生 HTML 元素<button><input><select>、自定义卡片 div 等
  • 重复造轮子的自定义组件:自定义弹窗、分页、加载状态、提示消息等
  • 可简化的内联逻辑:手动标签页切换、手动状态管理等

步骤 2: 查找合适的框架组件

先查组件目录确认有哪些可用组件:

Read: references/components-catalog.md

确定组件后,读取对应 README 了解完整 APIprops、slots、events

Read: packages/components/src/<component-name>/README.md

README 是最权威的用法来源,不确定时优先看文档而不是猜。

步骤 3: 参考优化模式(可选)

如果不确定如何替换,查看前后对比示例:

Read: references/optimization-patterns.md

步骤 4: 实施替换

替换时保留所有原始功能,不要改变业务逻辑。框架组件通常提供组合式函数用于编程式控制,优先使用:

  • useFaModal() — 编程式打开/关闭弹窗、confirm 确认框
  • useFaToast() — 显示成功/错误提示
  • useFaLoading() — 控制加载遮罩

组件可以组合使用,例如:

<FaCard title="用户列表">
  <FaSearchBar v-model="keyword" />
  <FaEmpty v-if="users.length === 0" />
  <template #footer>
    <FaPagination :page="page" :size="size" :total="total" />
  </template>
</FaCard>

步骤 5: 验证

Fa 组件通过 unplugin-auto-import 自动导入,无需手动写 import 语句。替换后确认 props 和 v-model 绑定符合组件 API。如有问题回到 packages/components/src/<component-name>/README.md 核对。