Files
knowledge-base/1 - Inbox/Claude Code 工程化指南:高效组织 .claude 目录.md
Yaojia Wang 26448c796e Merge remote-tracking branch 'origin/main'
# Conflicts:
#	4 - Resources/Claude-Code/Everything Claude Code 完整指南.md
2026-05-23 11:03:10 +02:00

6.2 KiB
Raw Permalink Blame History

title, source, author, published, created, description, tags
title source author published created description tags
Claude Code 工程化指南:高效组织 .claude/ 目录 https://x.com/vincemask/article/2056757482152960110
Vince 聊开发 (@vincemask)
2026-05-19 2026-05-20 为什么结构很重要?大多数 Claude Code 用户知道 .claude/ 文件夹的存在,但很少有人认真思考它的组织方式。项目小的时候,一个 CLAUDE.md、几个设置文件就够了。但随着项目增长指令变得难以维护工作流散落在错误的地方文件夹慢慢变成有用配置和难以解释的混乱...
clippings

Image

为什么结构很重要?

大多数 Claude Code 用户知道 .claude/ 文件夹的存在,但很少有人认真思考它的组织方式。项目小的时候,一个 CLAUDE.md、几个设置文件就够了。但随着项目增长指令变得难以维护工作流散落在错误的地方文件夹慢慢变成有用配置和难以解释的混乱的混合物。

一个组织良好的 .claude/ 文件夹让 Claude 更容易被引导、被信任,也更容易在真实项目中扩展。

目标结构蓝图

your-project/
├── CLAUDE.md              # 主项目指令
├── CLAUDE.local.md         # 个人覆盖(不提交)
└── .claude/
    ├── settings.json        # 控制层
    ├── settings.local.json  # 本地覆盖
    ├── rules/               # 模块化指令
    ├── hooks/               # 自动化脚本
    ├── commands/            # 可复用提示词工作流
    ├── skills/              # 打包能力
    └── agents/              # 专用子代理

核心原则

1. 顶层要轻

  • CLAUDE.md解释项目如何工作栈、架构、关键命令、全局约定
  • .claude/settings.json控制 Claude 在项目中的操作方式权限、hooks、项目级行为
  • CLAUDE.local.md / .claude/settings.local.json个人覆盖不进git版本控制

这两层分开:一个负责引导,一个负责控制

2. CLAUDE.md 与 rules/ 的划分

CLAUDE.md 放全局指导——每次会话都需要的内容:

  • 主要技术栈
  • 高层架构
  • 最重要的开发命令
  • 广泛适用的代码约定
  • 项目级警告或约束

rules/ 放专项指导——某个领域或工作流的规则:

.claude/
└── rules/
    ├── frontend.md
    ├── backend-api.md
    ├── testing.md
    └── data-pipelines.md

什么时候应该拆分成 rules/

  • CLAUDE.md 开始显得拥挤
  • 不同仓库区域需要不同指导
  • 不同人有不同标准
  • 团队经常更新约定
  • 想按路径限定指令作用域

CLAUDE.md 建议参考这篇文章进行调整

May 7

3. hooks/ 和 commands/ 分工

hooks/:自动运行的脚本,不放在说明文档中

清理或验证输出(如 format-edits.sh

强制执行工作流要求(如 run-tests-before-stop.sh

commands/:可复用的提示词工作流,不是自动运行的

  • 审查 PRreview-pr.md
  • 编写测试write-tests.md
  • 为发布准备变更摘要summarize-changes.md
.claude/
├── hooks/
│   ├── block-dangerous-commands.sh
│   ├── format-edits.sh
│   └── run-tests-before-stop.sh
└── commands/
    ├── review-pr.md
    ├── write-tests.md
    └── summarize-changes.md

命名要清晰:format-edits.sh 好过 script1.sh

4. skills/ 和 agents/ 的进阶结构

skills/:打包的能力,工作流有多个步骤、需要配套文档时使用

.claude/
└── skills/
    ├── release-prep/
    │   ├── SKILL.md
    │   └── release-template.md
    └── docs-audit/
        ├── SKILL.md
        └── style-guide.md

commands/ vs skills/ 的区别:

  • commands/ = 轻量可复用任务(一个文件就够了)
  • skills/ = 更丰富的打包工作流(多个步骤 + 配套文档)

agents/:专用子代理,需要更聚焦的角色时使用

.claude/
└── agents/
    ├── code-reviewer.md
    ├── security-auditor.md
    └── docs-writer.md

每个 skill 解决一个重复出现的完整工作流,每个 agent 拥有一个专门角色。如果两个文件高度重叠,应该合并或简化。

5. 团队结构 vs 个人结构的分离

# 项目级(团队共享)
your-project/
├── CLAUDE.md
└── .claude/
    ├── settings.json
    ├── rules/
    └── hooks/

# 用户级(个人偏好)
~/.claude/
├── CLAUDE.md
├── settings.json
├── skills/
├── agents/
└── projects/

判断标准:如果配置帮助整个团队更一致地工作 → 放项目级。如果主要反映一个人的工作流 → 放本地或全局设置。

本地覆盖文件CLAUDE.local.md 和 .claude/settings.local.json 是很好的中间层,让人可以在不污染版本控制的情况下调整行为。

渐进式成长路径

不要一开始就填满所有文件夹。按需增加:

  1. 起步CLAUDE.md + .claude/settings.json
  2. 指令膨胀:加 rules/
  3. 需要自动化:加 hooks/
  4. 提示词重复:加 commands/
  5. 工作流变深:加 skills/
  6. 需要专精角色:加 agents/

常见错误

Image

关键要点

最高效的 .claude/ 文件夹不是功能最丰富的,而是每个部分都有清晰用途的。好的结构应该能立即回答这些问题:

  • 项目级指令在哪里?
  • 模块化规则放哪里?
  • 自动化脚本放哪里?
  • 可复用工作流放哪里?
  • 哪些是共享的,哪些是私人的?
  • 哪些是活跃的,哪些只是实验?

当 .claude/ 组织好了Claude 用起来会可预测、可维护、易于团队共享。

Image