skills.mdx 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. ---
  2. title: "Skills:预制的能力包"
  3. description: "把常用的工作流封装成可复用的技能"
  4. ---
  5. {/* 本章目标:解释 Skills 系统的设计思想 */}
  6. ## Tool vs Skill
  7. | | Tool | Skill |
  8. |---|---|---|
  9. | 粒度 | 单个原子操作(读文件、执行命令) | 一套完整的工作流(代码审查、创建 PR) |
  10. | 触发方式 | AI 自主选择 | 用户主动调用(`/skill-name`)或 AI 根据场景推荐 |
  11. | 本质 | 执行逻辑 | 预制的 Prompt + 工具权限配置 |
  12. ## Skill 的三个来源
  13. <CardGroup cols={3}>
  14. <Card title="内置 Skill" icon="box">
  15. 编译进 CLI 的技能包。如 `/commit`、`/review`、`/debug`
  16. </Card>
  17. <Card title="项目 Skill" icon="folder-open">
  18. 项目 `.claude/skills/` 目录中的 Markdown 文件。团队共享
  19. </Card>
  20. <Card title="MCP Skill" icon="plug">
  21. 通过 MCP Server 提供的技能。动态发现
  22. </Card>
  23. </CardGroup>
  24. ## 一个 Skill 包含什么
  25. 每个 Skill 本质上是一个"AI 行为的预设":
  26. | 组成部分 | 作用 |
  27. |----------|------|
  28. | **名称和描述** | 告诉 AI 和用户这个技能做什么 |
  29. | **whenToUse** | 什么场景下应该使用这个技能(AI 据此自动推荐) |
  30. | **Prompt 模板** | 注入给 AI 的详细指令——相当于"操作手册" |
  31. | **allowedTools** | 这个技能允许使用哪些工具(能力边界) |
  32. | **model** | 可选指定使用的模型 |
  33. ## 设计精妙之处
  34. Skill 的核心洞见是:**很多复杂任务的关键不在于代码逻辑,而在于 Prompt 的质量**。
  35. 一个好的代码审查,不是写了什么代码来审查,而是:
  36. - 告诉 AI 审查的标准是什么
  37. - 告诉 AI 按什么顺序审查
  38. - 告诉 AI 输出什么格式的报告
  39. - 限制 AI 只能用读取类工具(不要边审查边改代码)
  40. Skill 把这些"经验"封装起来,任何人都能一键调用。
  41. ## 技能发现
  42. 当可用技能很多时,AI 可以通过 **SkillTool** 搜索匹配的技能:
  43. - 用户说"帮我做代码审查"
  44. - AI 搜索已注册的技能,发现 `code-review` 匹配
  45. - AI 调用该技能,按预设的流程执行