@momo-kits/native-kits 0.157.1-debug → 0.157.1-skill.1-debug
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/momo-native-kits/SKILL.md +87 -0
- package/.claude/momo-native-kits/references/Badge.md +39 -0
- package/.claude/momo-native-kits/references/BadgeDot.md +37 -0
- package/.claude/momo-native-kits/references/BottomSheet.md +51 -0
- package/.claude/momo-native-kits/references/BottomTab.md +65 -0
- package/.claude/momo-native-kits/references/Button.md +197 -0
- package/.claude/momo-native-kits/references/CheckBox.md +51 -0
- package/.claude/momo-native-kits/references/Chip.md +47 -0
- package/.claude/momo-native-kits/references/Divider.md +29 -0
- package/.claude/momo-native-kits/references/HeaderTitle.md +45 -0
- package/.claude/momo-native-kits/references/HeaderType.md +47 -0
- package/.claude/momo-native-kits/references/Icon.md +32 -0
- package/.claude/momo-native-kits/references/Image.md +38 -0
- package/.claude/momo-native-kits/references/Information.md +36 -0
- package/.claude/momo-native-kits/references/Input.md +334 -0
- package/.claude/momo-native-kits/references/InputDropDown.md +47 -0
- package/.claude/momo-native-kits/references/InputMoney.md +241 -0
- package/.claude/momo-native-kits/references/InputOTP.md +52 -0
- package/.claude/momo-native-kits/references/InputPhoneNumber.md +175 -0
- package/.claude/momo-native-kits/references/InputSearch.md +57 -0
- package/.claude/momo-native-kits/references/InputTextArea.md +46 -0
- package/.claude/momo-native-kits/references/NavigationContainer.md +51 -0
- package/.claude/momo-native-kits/references/Navigator.md +287 -0
- package/.claude/momo-native-kits/references/PaginationDot.md +28 -0
- package/.claude/momo-native-kits/references/PaginationNumber.md +28 -0
- package/.claude/momo-native-kits/references/PopupNotify.md +47 -0
- package/.claude/momo-native-kits/references/Radio.md +44 -0
- package/.claude/momo-native-kits/references/Skeleton.md +32 -0
- package/.claude/momo-native-kits/references/Switch.md +36 -0
- package/.claude/momo-native-kits/references/Tag.md +40 -0
- package/.claude/momo-native-kits/references/Text.md +37 -0
- package/.claude/momo-native-kits/references/Title.md +43 -0
- package/.claude/momo-native-kits/references/Tooltip.md +30 -0
- package/.claude/settings.local.json +13 -0
- package/building-skill-for-claude.md +1190 -0
- package/compose/build.gradle.kts +1 -1
- package/compose/compose.podspec +1 -1
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Button.kt +51 -33
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tooltip.kt +41 -27
- package/gradle.properties +1 -1
- package/ios/Input/InputPhoneNumber.swift +2 -1
- package/local.properties +8 -0
- package/package.json +1 -1
|
@@ -0,0 +1,1190 @@
|
|
|
1
|
+
# Hướng Dẫn Toàn Diện Xây Dựng Skills Cho Claude
|
|
2
|
+
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
## Mục lục
|
|
6
|
+
|
|
7
|
+
- [Giới thiệu](#giới-thiệu)
|
|
8
|
+
- [Cơ bản](#chương-1-cơ-bản)
|
|
9
|
+
- [Lập kế hoạch và thiết kế](#chương-2-lập-kế-hoạch-và-thiết-kế)
|
|
10
|
+
- [Kiểm thử và cải tiến](#chương-3-kiểm-thử-và-cải-tiến)
|
|
11
|
+
- [Phân phối và chia sẻ](#chương-4-phân-phối-và-chia-sẻ)
|
|
12
|
+
- [Các mẫu và xử lý sự cố](#chương-5-các-mẫu-và-xử-lý-sự-cố)
|
|
13
|
+
- [Tài nguyên và tham khảo](#chương-6-tài-nguyên-và-tham-khảo)
|
|
14
|
+
|
|
15
|
+
---
|
|
16
|
+
|
|
17
|
+
## Giới thiệu
|
|
18
|
+
|
|
19
|
+
Một skill là một bộ hướng dẫn - được đóng gói thành một thư mục đơn giản - dạy cho Claude cách xử lý các tác vụ hoặc quy trình cụ thể. Skills là một trong những cách mạnh mẽ nhất để tùy chỉnh Claude cho nhu cầu cụ thể của bạn. Thay vì phải giải thích lại sở thích, quy trình và chuyên môn của bạn trong mỗi cuộc trò chuyện, skills cho phép bạn dạy Claude một lần và hưởng lợi mỗi khi sử dụng.
|
|
20
|
+
|
|
21
|
+
Skills đặc biệt mạnh mẽ khi bạn có các quy trình có thể lặp lại: tạo thiết kế frontend từ spec, thực hiện nghiên cứu với phương pháp nhất quán, tạo tài liệu theo style guide của team, hoặc điều phối các quy trình nhiều bước. Chúng hoạt động tốt với các khả năng tích hợp sẵn của Claude như thực thi code và tạo tài liệu. Đối với những người xây dựng tích hợp MCP, skills bổ sung thêm một lớp mạnh mẽ giúp chuyển đổi quyền truy cập công cụ thô thành các quy trình đáng tin cậy và được tối ưu hóa.
|
|
22
|
+
|
|
23
|
+
Hướng dẫn này bao gồm mọi thứ bạn cần biết để xây dựng skills hiệu quả - từ lập kế hoạch và cấu trúc đến kiểm thử và phân phối. Cho dù bạn đang xây dựng skill cho bản thân, team hay cộng đồng, bạn sẽ tìm thấy các mẫu thực tế và ví dụ thực tế xuyên suốt.
|
|
24
|
+
|
|
25
|
+
**Bạn sẽ học được:**
|
|
26
|
+
|
|
27
|
+
- Yêu cầu kỹ thuật và best practices cho cấu trúc skill
|
|
28
|
+
- Các mẫu cho skills độc lập và quy trình làm việc nâng cao với MCP
|
|
29
|
+
- Các mẫu chúng tôi đã thấy hoạt động tốt trong các trường hợp sử dụng khác nhau
|
|
30
|
+
- Cách kiểm thử, cải tiến và phân phối skills của bạn
|
|
31
|
+
|
|
32
|
+
**Đối tượng:**
|
|
33
|
+
|
|
34
|
+
- Developers muốn Claude tuân theo các quy trình cụ thể một cách nhất quán
|
|
35
|
+
- Power users muốn Claude tuân theo các quy trình cụ thể
|
|
36
|
+
- Teams muốn chuẩn hóa cách Claude hoạt động trong tổ chức
|
|
37
|
+
|
|
38
|
+
### Hai Con Đường Qua Hướng Dẫn Này
|
|
39
|
+
|
|
40
|
+
Xây dựng skills độc lập? Tập trung vào **Cơ bản**, **Lập kế hoạch và Thiết kế**, và mục 1-2. Nâng cao tích hợp MCP? Phần "Skills + MCP" và mục 3 dành cho bạn. Cả hai con đường đều chia sẻ cùng yêu cầu kỹ thuật, nhưng bạn chọn những gì phù hợp với trường hợp sử dụng của mình.
|
|
41
|
+
|
|
42
|
+
**Bạn sẽ nhận được gì từ hướng dẫn này:** Đến cuối, bạn sẽ có thể xây dựng một skill hoạt động trong một buổi. Dự kiến khoảng 15-30 phút để xây dựng và kiểm thử skill đầu tiên của bạn bằng skill-creator.
|
|
43
|
+
|
|
44
|
+
---
|
|
45
|
+
|
|
46
|
+
## Chương 1: Cơ Bản
|
|
47
|
+
|
|
48
|
+
### Skill là gì?
|
|
49
|
+
|
|
50
|
+
Một skill là một thư mục chứa:
|
|
51
|
+
|
|
52
|
+
- **SKILL.md** (bắt buộc): Hướng dẫn bằng Markdown với YAML frontmatter
|
|
53
|
+
- **scripts/** (tùy chọn): Code thực được (Python, Bash, v.v.)
|
|
54
|
+
- **references/** (tùy chọn): Tài liệu được tải khi cần
|
|
55
|
+
- **assets/** (tùy chọn): Templates, fonts, icons được sử dụng trong output
|
|
56
|
+
|
|
57
|
+
### Nguyên tắc thiết kế cốt lõi
|
|
58
|
+
|
|
59
|
+
#### Hiển thị Tăng dần (Progressive Disclosure)
|
|
60
|
+
|
|
61
|
+
Skills sử dụng hệ thống ba cấp độ:
|
|
62
|
+
|
|
63
|
+
- **Cấp độ 1** (YAML frontmatter): Luôn được tải vào system prompt của Claude. Cung cấp đủ thông tin để Claude biết khi nào mỗi skill nên được sử dụng mà không cần tải tất cả vào context.
|
|
64
|
+
- **Cấp độ 2** (Phần body của SKILL.md): Được tải khi Claude nghĩ rằng skill liên quan đến tác vụ hiện tại. Chứa hướng dẫn đầy đủ.
|
|
65
|
+
- **Cấp độ 3** (Các file liên kết): Các file bổ sung được đóng gói trong thư mục skill mà Claude có thể chọn để điều hướng và khám phá khi cần.
|
|
66
|
+
|
|
67
|
+
Việc hiển thị tăng dần này giúp giảm thiểu token usage trong khi vẫn duy trì chuyên môn chuyên sâu.
|
|
68
|
+
|
|
69
|
+
#### Khả năng Kết hợp (Composability)
|
|
70
|
+
|
|
71
|
+
Claude có thể tải nhiều skills cùng lúc. Skill của bạn nên hoạt động tốt cùng với các skill khác, không giả định đó là khả năng duy nhất.
|
|
72
|
+
|
|
73
|
+
#### Khả năng Di chuyển (Portability)
|
|
74
|
+
|
|
75
|
+
Skills hoạt động giống nhau trên Claude.ai, Claude Code và API. Tạo skill một lần và nó hoạt động trên tất cả các nền tảng mà không cần sửa đổi, miễn là môi trường hỗ trợ các dependencies mà skill yêu cầu.
|
|
76
|
+
|
|
77
|
+
### Dành cho MCP Builders: Skills + Connectors
|
|
78
|
+
|
|
79
|
+
> 💡 **Lưu ý:** Xây dựng skills độc lập mà không có MCP? Bỏ qua phần này và đến phần **Lập kế hoạch và Thiết kế** - bạn có thể quay lại sau.
|
|
80
|
+
|
|
81
|
+
Nếu bạn đã có một MCP server hoạt động, bạn đã làm phần khó nhất. Skills là lớp knowledge bên trên - nắm bắt các quy trình và best practices mà bạn đã biết, để Claude có thể áp dụng chúng một cách nhất quán.
|
|
82
|
+
|
|
83
|
+
#### Analogy về nhà bếp
|
|
84
|
+
|
|
85
|
+
- **MCP** cung cấp nhà bếp chuyên nghiệp: quyền truy cập công cụ, nguyên liệu và thiết bị.
|
|
86
|
+
- **Skills** cung cấp công thức nấu ăn: hướng dẫn từng bước về cách tạo ra thứ có giá trị.
|
|
87
|
+
|
|
88
|
+
Cùng nhau, chúng cho phép người dùng hoàn thành các tác vụ phức tạp mà không cần tự mình tìm ra từng bước.
|
|
89
|
+
|
|
90
|
+
#### Cách chúng hoạt động cùng nhau
|
|
91
|
+
|
|
92
|
+
| MCP (Kết nối) | Skills (Kiến thức) |
|
|
93
|
+
|---------------|-------------------|
|
|
94
|
+
| Kết nối Claude với dịch vụ của bạn (Notion, Asana, Linear, v.v.) | Dạy Claude cách sử dụng dịch vụ của bạn một cách hiệu quả |
|
|
95
|
+
| Cung cấp truy cập dữ liệu thời gian thực và gọi công cụ | Nắm bắt các quy trình và best practices |
|
|
96
|
+
| **Điều Claude CÓ THỂ làm** | **Điều Claude NÊN làm** |
|
|
97
|
+
|
|
98
|
+
#### Tại sao điều này quan trọng cho người dùng MCP của bạn
|
|
99
|
+
|
|
100
|
+
**Không có skills:**
|
|
101
|
+
- Người dùng kết nối MCP của bạn nhưng không biết phải làm gì tiếp
|
|
102
|
+
- Ticket hỏi "làm thế nào để làm X với tích hợp của bạn"
|
|
103
|
+
- Mỗi cuộc trò chuyện bắt đầu từ đầu
|
|
104
|
+
- Kết quả không nhất quán vì người dùng prompt khác nhau mỗi lần
|
|
105
|
+
- Người dùng đổ lỗi cho connector khi vấn đề thực sự là hướng dẫn quy trình
|
|
106
|
+
|
|
107
|
+
**Với skills:**
|
|
108
|
+
- Quy trình được xây dựng sẵn tự động kích hoạt khi cần
|
|
109
|
+
- Sử dụng công cụ nhất quán và đáng tin cậy
|
|
110
|
+
- Best practices được nhúng trong mỗi tương tác
|
|
111
|
+
- Đường cong học tập thấp hơn cho tích hợp của bạn
|
|
112
|
+
|
|
113
|
+
---
|
|
114
|
+
|
|
115
|
+
## Chương 2: Lập Kế Hoạch và Thiết Kế
|
|
116
|
+
|
|
117
|
+
### Bắt đầu với các trường hợp sử dụng
|
|
118
|
+
|
|
119
|
+
Trước khi viết bất kỳ code nào, xác định 2-3 trường hợp sử dụng cụ thể mà skill của bạn nên hỗ trợ.
|
|
120
|
+
|
|
121
|
+
**Định nghĩa trường hợp sử dụng tốt:**
|
|
122
|
+
|
|
123
|
+
```
|
|
124
|
+
Trường hợp sử dụng: Lập kế hoạch Sprint Dự án
|
|
125
|
+
Kích hoạt: Người dùng nói "giúp tôi lập kế hoạch sprint này" hoặc "tạo task sprint"
|
|
126
|
+
|
|
127
|
+
Các bước:
|
|
128
|
+
1. Lấy trạng thái dự án hiện tại từ Linear (qua MCP)
|
|
129
|
+
2. Phân tích velocity và capacity của team
|
|
130
|
+
3. Đề xuất ưu tiên task
|
|
131
|
+
4. Tạo task trong Linear với labels và estimates phù hợp
|
|
132
|
+
|
|
133
|
+
Kết quả: Sprint đã lập kế hoạch đầy đủ với các task đã tạo
|
|
134
|
+
```
|
|
135
|
+
|
|
136
|
+
**Tự hỏi bản thân:**
|
|
137
|
+
- Người dùng muốn đạt được gì?
|
|
138
|
+
- Quy trình nhiều bước nào được yêu cầu?
|
|
139
|
+
- Công cụ nào cần thiết (built-in hay MCP?)
|
|
140
|
+
- Kiến thức domain hoặc best practices nào nên được nhúng?
|
|
141
|
+
|
|
142
|
+
### Các danh mục trường hợp sử dụng skill phổ biến
|
|
143
|
+
|
|
144
|
+
Tại Anthropic, chúng tôi đã quan sát ba trường hợp sử dụng phổ biến:
|
|
145
|
+
|
|
146
|
+
#### Danh mục 1: Tạo Tài liệu & Tài sản
|
|
147
|
+
|
|
148
|
+
**Sử dụng cho:** Tạo output nhất quán và chất lượng cao bao gồm tài liệu, presentations, apps, designs, code, v.v.
|
|
149
|
+
|
|
150
|
+
**Ví dụ thực tế:** frontend-design skill (xem thêm skills cho docx, pptx, xlsx, và ppt)
|
|
151
|
+
|
|
152
|
+
> "Tạo giao diện frontend production-grade với chất lượng thiết kế cao. Sử dụng khi xây dựng web components, pages, artifacts, posters, hoặc applications."
|
|
153
|
+
|
|
154
|
+
**Kỹ thuật chính:**
|
|
155
|
+
- Style guides và brand standards được nhúng
|
|
156
|
+
- Cấu trúc template cho output nhất quán
|
|
157
|
+
- Quality checklists trước khi hoàn thiện
|
|
158
|
+
- Không cần công cụ bên ngoài - sử dụng khả năng built-in của Claude
|
|
159
|
+
|
|
160
|
+
#### Danh mục 2: Tự động hóa Quy trình
|
|
161
|
+
|
|
162
|
+
**Sử dụng cho:** Các quy trình nhiều bước được hưởng lợi từ phương pháp nhất quán, bao gồm điều phối qua nhiều MCP servers.
|
|
163
|
+
|
|
164
|
+
**Ví dụ thực tế:** skill-creator skill
|
|
165
|
+
|
|
166
|
+
> "Hướng dẫn tương tác để tạo skills mới. Dẫn dắt người dùng qua định nghĩa trường hợp sử dụng, tạo frontmatter, viết hướng dẫn và validation."
|
|
167
|
+
|
|
168
|
+
**Kỹ thuật chính:**
|
|
169
|
+
- Quy trình từng bước với các cổng validation
|
|
170
|
+
- Templates cho các cấu trúc phổ biến
|
|
171
|
+
- Đề xuất review và cải tiến được tích hợp
|
|
172
|
+
- Vòng lặp cải tiến lặp lại
|
|
173
|
+
|
|
174
|
+
#### Danh mục 3: Nâng cao MCP
|
|
175
|
+
|
|
176
|
+
**Sử dụng cho:** Hướng dẫn quy trình để nâng cao quyền truy cập công cụ mà một MCP server cung cấp.
|
|
177
|
+
|
|
178
|
+
**Ví dụ thực tế:** sentry-code-review skill (từ Sentry)
|
|
179
|
+
|
|
180
|
+
> "Tự động phân tích và sửa lỗi được phát hiện trong GitHub Pull Requests sử dụng dữ liệu giám sát lỗi của Sentry qua MCP server của họ."
|
|
181
|
+
|
|
182
|
+
**Kỹ thuật chính:**
|
|
183
|
+
- Điều phối nhiều lệnh gọi MCP theo trình tự
|
|
184
|
+
- Nhúng chuyên môn domain
|
|
185
|
+
- Cung cấp context mà người dùng otherwise cần chỉ định
|
|
186
|
+
- Xử lý lỗi cho các vấn đề MCP phổ biến
|
|
187
|
+
|
|
188
|
+
### Định nghĩa tiêu chí thành công
|
|
189
|
+
|
|
190
|
+
Làm thế nào để biết skill của bạn đang hoạt động?
|
|
191
|
+
|
|
192
|
+
Đây là các mục tiêu mang tính lý tưởng - các điểm benchmark gần đúng hơn là ngưỡng chính xác. Hướng tới sự nghiêm ngặt nhưng chấp nhận rằng sẽ có yếu tố đánh giá dựa trên cảm tính. Chúng tôi đang phát triển hướng dẫn đo lường và công cụ mạnh mẽ hơn.
|
|
193
|
+
|
|
194
|
+
#### Metrics định lượng:
|
|
195
|
+
|
|
196
|
+
- **Skill kích hoạt trên 90% các truy vấn liên quan**
|
|
197
|
+
- Cách đo: Chạy 10-20 truy vấn test nên kích hoạt skill. Theo dõi bao nhiêu lần nó tự động tải so với yêu cầu gọi rõ ràng.
|
|
198
|
+
- **Hoàn thành quy trình trong X lệnh gọi công cụ**
|
|
199
|
+
- Cách đo: So sánh cùng một tác vụ có và không có skill. Đếm số lệnh gọi công cụ và tổng tokens tiêu thụ.
|
|
200
|
+
- **0 lệnh gọi API thất bại mỗi quy trình**
|
|
201
|
+
- Cách đo: Theo dõi logs của MCP server trong các lần chạy test. Theo dõi tỷ lệ thử lại và mã lỗi.
|
|
202
|
+
|
|
203
|
+
#### Metrics định tính:
|
|
204
|
+
|
|
205
|
+
- **Người dùng không cần prompt Claude về các bước tiếp theo**
|
|
206
|
+
- Cách đánh giá: Trong quá trình test, chú ý tần suất bạn cần điều hướng hoặc làm rõ. Xin phản hồi từ người dùng beta.
|
|
207
|
+
- **Quy trình hoàn thành không cần người dùng sửa**
|
|
208
|
+
- Cách đánh giá: Chạy cùng yêu cầu 3-5 lần. So sánh output về tính nhất quán cấu trúc và chất lượng.
|
|
209
|
+
- **Kết quả nhất quán giữa các phiên**
|
|
210
|
+
- Cách đánh giá: Người dùng mới có thể hoàn thành tác vụ trong lần thử đầu tiên với hướng dẫn tối thiểu?
|
|
211
|
+
|
|
212
|
+
### Yêu cầu Kỹ thuật
|
|
213
|
+
|
|
214
|
+
#### Cấu trúc File
|
|
215
|
+
|
|
216
|
+
```
|
|
217
|
+
your-skill-name/
|
|
218
|
+
├── SKILL.md # Bắt buộc - file skill chính
|
|
219
|
+
├── scripts/ # Tùy chọn - code thực thi
|
|
220
|
+
│ ├── process_data.py # Ví dụ
|
|
221
|
+
│ └── validate.sh # Ví dụ
|
|
222
|
+
├── references/ # Tùy chọn - tài liệu
|
|
223
|
+
│ ├── api-guide.md # Ví dụ
|
|
224
|
+
│ └── examples/ # Ví dụ
|
|
225
|
+
└── assets/ # Tùy chọn - templates, v.v.
|
|
226
|
+
└── report-template.md # Ví dụ
|
|
227
|
+
```
|
|
228
|
+
|
|
229
|
+
#### Quy tắc quan trọng
|
|
230
|
+
|
|
231
|
+
**Đặt tên SKILL.md:**
|
|
232
|
+
- Phải chính xác là `SKILL.md` (phân biệt hoa thường)
|
|
233
|
+
- Không chấp nhận các biến thể (SKILL.MD, skill.md, v.v.)
|
|
234
|
+
|
|
235
|
+
**Đặt tên thư mục skill:**
|
|
236
|
+
- Sử dụng kebab-case: `notion-project-setup` ✅
|
|
237
|
+
- Không có dấu cách: `Notion Project Setup` ❌
|
|
238
|
+
- Không có dấu gạch dưới: `notion_project_setup` ❌
|
|
239
|
+
- Không có viết hoa: `NotionProjectSetup` ❌
|
|
240
|
+
|
|
241
|
+
**Không có README.md:**
|
|
242
|
+
- Không bao gồm README.md trong thư mục skill của bạn
|
|
243
|
+
- Tất cả tài liệu đi vào SKILL.md hoặc references/
|
|
244
|
+
- Lưu ý: khi phân phối qua GitHub, bạn vẫn muốn có README.md ở cấp repo cho người dùng — xem phần Phân phối và Chia sẻ.
|
|
245
|
+
|
|
246
|
+
### YAML frontmatter: Phần quan trọng nhất
|
|
247
|
+
|
|
248
|
+
YAML frontmatter là cách Claude quyết định có tải skill của bạn hay không. Làm điều này đúng.
|
|
249
|
+
|
|
250
|
+
#### Định dạng tối thiểu bắt buộc
|
|
251
|
+
|
|
252
|
+
```yaml
|
|
253
|
+
---
|
|
254
|
+
name: your-skill-name
|
|
255
|
+
description: What it does. Use when user asks to [specific phrases].
|
|
256
|
+
---
|
|
257
|
+
```
|
|
258
|
+
|
|
259
|
+
Đó là tất cả những gì bạn cần để bắt đầu.
|
|
260
|
+
|
|
261
|
+
#### Yêu cầu trường
|
|
262
|
+
|
|
263
|
+
**name** (bắt buộc):
|
|
264
|
+
- Chỉ sử dụng kebab-case
|
|
265
|
+
- Không có dấu cách hoặc viết hoa
|
|
266
|
+
- Nên khớp với tên thư mục
|
|
267
|
+
|
|
268
|
+
**description** (bắt buộc):
|
|
269
|
+
- PHẢI bao gồm CẢ HAI:
|
|
270
|
+
- Skill làm gì
|
|
271
|
+
- Khi nào sử dụng nó (điều kiện kích hoạt)
|
|
272
|
+
- Dưới 1024 ký tự
|
|
273
|
+
- Không có thẻ XML (`<` hoặc `>`)
|
|
274
|
+
- Bao gồm các cụm từ cụ thể mà người dùng có thể nói
|
|
275
|
+
- Đề cập các loại file nếu liên quan
|
|
276
|
+
|
|
277
|
+
**license** (tùy chọn):
|
|
278
|
+
- Sử dụng nếu làm skill open source
|
|
279
|
+
- Phổ biến: MIT, Apache-2.0
|
|
280
|
+
|
|
281
|
+
**compatibility** (tùy chọn)
|
|
282
|
+
- 1-500 ký tự
|
|
283
|
+
- Cho biết yêu cầu môi trường: ví dụ sản phẩm dự định, gói hệ thống cần thiết, nhu cầu truy cập mạng, v.v.
|
|
284
|
+
|
|
285
|
+
**metadata** (tùy chọn):
|
|
286
|
+
- Bất kỳ cặp key-value tùy chỉnh nào
|
|
287
|
+
- Đề xuất: author, version, mcp-server
|
|
288
|
+
- Ví dụ:
|
|
289
|
+
```yaml
|
|
290
|
+
metadata:
|
|
291
|
+
author: ProjectHub
|
|
292
|
+
version: 1.0.0
|
|
293
|
+
mcp-server: projecthub
|
|
294
|
+
```
|
|
295
|
+
|
|
296
|
+
#### Hạn chế bảo mật
|
|
297
|
+
|
|
298
|
+
**Cấm trong frontmatter:**
|
|
299
|
+
- Dấu ngoặc góc XML (`<` `>`)
|
|
300
|
+
- Skills có "claude" hoặc "anthropic" trong tên (đã đặt trước)
|
|
301
|
+
|
|
302
|
+
Tại sao: Frontmatter xuất hiện trong system prompt của Claude. Nội dung độc hại có thể inject hướng dẫn.
|
|
303
|
+
|
|
304
|
+
### Viết Skills Hiệu quả
|
|
305
|
+
|
|
306
|
+
#### Trường description
|
|
307
|
+
|
|
308
|
+
Theo blog kỹ thuật của Anthropic: "Metadata này...cung cấp đủ thông tin để Claude biết khi nào mỗi skill nên được sử dụng mà không cần tải tất cả vào context." Đây là cấp độ đầu tiên của progressive disclosure.
|
|
309
|
+
|
|
310
|
+
**Cấu trúc:**
|
|
311
|
+
[Skill làm gì] + [Khi nào sử dụng] + [Khả năng chính]
|
|
312
|
+
|
|
313
|
+
**Ví dụ mô tả tốt:**
|
|
314
|
+
|
|
315
|
+
```yaml
|
|
316
|
+
# Tốt - cụ thể và có thể hành động
|
|
317
|
+
description: Analyzes Figma design files and generates
|
|
318
|
+
developer handoff documentation. Use when user uploads .fig
|
|
319
|
+
files, asks for "design specs", "component documentation", or
|
|
320
|
+
"design-to-code handoff".
|
|
321
|
+
|
|
322
|
+
# Tốt - bao gồm cụm từ kích hoạt
|
|
323
|
+
description: Manages Linear project workflows including sprint
|
|
324
|
+
planning, task creation, and status tracking. Use when user
|
|
325
|
+
mentions "sprint", "Linear tasks", "project planning", or asks
|
|
326
|
+
to "create tickets".
|
|
327
|
+
|
|
328
|
+
# Tốt - đề xuất giá trị rõ ràng
|
|
329
|
+
description: End-to-end customer onboarding workflow for
|
|
330
|
+
PayFlow. Handles account creation, payment setup, and
|
|
331
|
+
subscription management. Use when user says "onboard new
|
|
332
|
+
customer", "set up subscription", or "create PayFlow account".
|
|
333
|
+
```
|
|
334
|
+
|
|
335
|
+
**Ví dụ mô tả xấu:**
|
|
336
|
+
|
|
337
|
+
```yaml
|
|
338
|
+
# Quá mơ hồ
|
|
339
|
+
description: Helps with projects.
|
|
340
|
+
|
|
341
|
+
# Thiếu điều kích hoạt
|
|
342
|
+
description: Creates sophisticated multi-page documentation
|
|
343
|
+
systems.
|
|
344
|
+
|
|
345
|
+
# Quá kỹ thuật, không có trigger cho người dùng
|
|
346
|
+
description: Implements the Project entity model with
|
|
347
|
+
hierarchical relationships.
|
|
348
|
+
```
|
|
349
|
+
|
|
350
|
+
#### Viết hướng dẫn chính
|
|
351
|
+
|
|
352
|
+
Sau frontmatter, viết hướng dẫn thực tế bằng Markdown.
|
|
353
|
+
|
|
354
|
+
**Cấu trúc được khuyến nghị:**
|
|
355
|
+
|
|
356
|
+
```markdown
|
|
357
|
+
---
|
|
358
|
+
name: your-skill
|
|
359
|
+
description: [Mô tả.]
|
|
360
|
+
---
|
|
361
|
+
|
|
362
|
+
# Your Skill Name
|
|
363
|
+
|
|
364
|
+
## Hướng dẫn
|
|
365
|
+
|
|
366
|
+
### Bước 1: [Bước Chính Đầu Tiên]
|
|
367
|
+
Giải thích rõ ràng điều gì xảy ra.
|
|
368
|
+
|
|
369
|
+
Ví dụ:
|
|
370
|
+
```bash
|
|
371
|
+
python scripts/fetch_data.py --project-id PROJECT_ID
|
|
372
|
+
```
|
|
373
|
+
Kết quả mong đợi: [mô tả thành công như thế nào]
|
|
374
|
+
```
|
|
375
|
+
|
|
376
|
+
(Thêm nhiều bước khi cần)
|
|
377
|
+
|
|
378
|
+
### Ví dụ
|
|
379
|
+
|
|
380
|
+
**Ví dụ 1:** [Kịch bản phổ biến]
|
|
381
|
+
- Người dùng nói: "Set up a new marketing campaign"
|
|
382
|
+
- Hành động:
|
|
383
|
+
1. Fetch existing campaigns via MCP
|
|
384
|
+
2. Create new campaign with provided parameters
|
|
385
|
+
- Kết quả: Campaign created with confirmation link
|
|
386
|
+
|
|
387
|
+
(Thêm nhiều ví dụ khi cần)
|
|
388
|
+
|
|
389
|
+
### Xử lý sự cố
|
|
390
|
+
|
|
391
|
+
**Lỗi:** [Thông báo lỗi phổ biến]
|
|
392
|
+
- Nguyên nhân: [Tại sao nó xảy ra]
|
|
393
|
+
- Giải pháp: [Cách sửa]
|
|
394
|
+
|
|
395
|
+
(Thêm nhiều trường hợp lỗi khi cần)
|
|
396
|
+
|
|
397
|
+
### Best Practices cho Hướng dẫn
|
|
398
|
+
|
|
399
|
+
#### Cụ thể và Có thể hành động
|
|
400
|
+
|
|
401
|
+
✅ **Tốt:**
|
|
402
|
+
```
|
|
403
|
+
Run `python scripts/validate.py --input {filename}` to check
|
|
404
|
+
data format.
|
|
405
|
+
|
|
406
|
+
If validation fails, common issues include:
|
|
407
|
+
- Missing required fields (add them to the CSV)
|
|
408
|
+
- Invalid date formats (use YYYY-MM-DD)
|
|
409
|
+
```
|
|
410
|
+
|
|
411
|
+
❌ **Xấu:**
|
|
412
|
+
```
|
|
413
|
+
Validate the data before proceeding.
|
|
414
|
+
```
|
|
415
|
+
|
|
416
|
+
#### Bao gồm xử lý lỗi
|
|
417
|
+
|
|
418
|
+
```markdown
|
|
419
|
+
### Vấn đề Phổ biến
|
|
420
|
+
|
|
421
|
+
#### MCP Connection Failed
|
|
422
|
+
If you see "Connection refused":
|
|
423
|
+
1. Verify MCP server is running: Check Settings > Extensions
|
|
424
|
+
2. Confirm API key is valid
|
|
425
|
+
3. Try reconnecting: Settings > Extensions > [Your Service] > Reconnect
|
|
426
|
+
```
|
|
427
|
+
|
|
428
|
+
#### Tham chiếu tài nguyên được đóng gói rõ ràng
|
|
429
|
+
|
|
430
|
+
```
|
|
431
|
+
Before writing queries, consult `references/api-patterns.md` for:
|
|
432
|
+
- Rate limiting guidance
|
|
433
|
+
- Pagination patterns
|
|
434
|
+
- Error codes and handling
|
|
435
|
+
```
|
|
436
|
+
|
|
437
|
+
#### Sử dụng Progressive Disclosure
|
|
438
|
+
|
|
439
|
+
Giữ SKILL.md tập trung vào hướng dẫn cốt lõi. Di chuyển tài liệu chi tiết vào `references/` và liên kết đến nó. (Xem Nguyên tắc Thiết kế Cốt lõi để biết cách hệ thống ba cấp độ hoạt động.)
|
|
440
|
+
|
|
441
|
+
---
|
|
442
|
+
|
|
443
|
+
## Chương 3: Kiểm Thử và Cải Tiến
|
|
444
|
+
|
|
445
|
+
Skills có thể được kiểm thử ở các mức độ nghiêm ngặt khác nhau tùy thuộc vào nhu cầu của bạn:
|
|
446
|
+
|
|
447
|
+
- **Kiểm thử thủ công trong Claude.ai** - Chạy truy vấn trực tiếp và quan sát hành vi. Iteration nhanh, không cần thiết lập.
|
|
448
|
+
- **Kiểm thử có script trong Claude Code** - Tự động hóa các test cases để validation có thể lặp lại qua các thay đổi.
|
|
449
|
+
- **Kiểm thử lập trình qua Skills API** - Xây dựng bộ đánh giá chạy có hệ thống với các test sets đã định nghĩa.
|
|
450
|
+
|
|
451
|
+
Chọn cách tiếp cận phù hợp với yêu cầu chất lượng và mức độ hiển thị của skill. Skill được sử dụng nội bộ bởi một team nhỏ có nhu cầu kiểm thử khác với skill được triển khai cho hàng nghìn người dùng doanh nghiệp.
|
|
452
|
+
|
|
453
|
+
> **Pro Tip:** Iteration trên một tác vụ trước khi mở rộng
|
|
454
|
+
>
|
|
455
|
+
> Chúng tôi nhận thấy những người tạo skill hiệu quả nhất iteration trên một tác vụ khó cho đến khi Claude thành công, sau đó trích xuất cách tiếp cận chiến thắng vào một skill. Điều này tận dụng in-context learning của Claude và cung cấp signal nhanh hơn so với kiểm thử rộng. Khi đã có nền tảng hoạt động, mở rộng sang nhiều test cases để coverage.
|
|
456
|
+
|
|
457
|
+
### Phương pháp Kiểm thử Được khuyến nghị
|
|
458
|
+
|
|
459
|
+
Dựa trên kinh nghiệm ban đầu, kiểm thử skills hiệu quả thường bao gồm ba lĩnh vực:
|
|
460
|
+
|
|
461
|
+
#### 1. Kiểm tra Kích hoạt
|
|
462
|
+
|
|
463
|
+
**Mục tiêu:** Đảm bảo skill của bạn tải vào đúng lúc.
|
|
464
|
+
|
|
465
|
+
**Test cases:**
|
|
466
|
+
- ✅ Kích hoạt trên các tác vụ rõ ràng
|
|
467
|
+
- ✅ Kích hoạt trên các yêu cầu được diễn giải lại
|
|
468
|
+
- ❌ Không kích hoạt trên các chủ đề không liên quan
|
|
469
|
+
|
|
470
|
+
**Ví dụ test suite:**
|
|
471
|
+
|
|
472
|
+
*Nên kích hoạt:*
|
|
473
|
+
- "Help me set up a new ProjectHub workspace"
|
|
474
|
+
- "I need to create a project in ProjectHub"
|
|
475
|
+
- "Initialize a ProjectHub project for Q4 planning"
|
|
476
|
+
|
|
477
|
+
*Không nên kích hoạt:*
|
|
478
|
+
- "What's the weather in San Francisco?"
|
|
479
|
+
- "Help me write Python code"
|
|
480
|
+
- "Create a spreadsheet" (trừ khi ProjectHub skill xử lý sheets)
|
|
481
|
+
|
|
482
|
+
#### 2. Kiểm tra Chức năng
|
|
483
|
+
|
|
484
|
+
**Mục tiêu:** Xác minh skill tạo ra output đúng.
|
|
485
|
+
|
|
486
|
+
**Test cases:**
|
|
487
|
+
- Output hợp lệ được tạo
|
|
488
|
+
- Lệnh gọi API thành công
|
|
489
|
+
- Xử lý lỗi hoạt động
|
|
490
|
+
- Edge cases được cover
|
|
491
|
+
|
|
492
|
+
**Ví dụ:**
|
|
493
|
+
|
|
494
|
+
```
|
|
495
|
+
Test: Create project with 5 tasks
|
|
496
|
+
Given: Project name "Q4 Planning", 5 task descriptions
|
|
497
|
+
When: Skill executes workflow
|
|
498
|
+
Then:
|
|
499
|
+
- Project created in ProjectHub
|
|
500
|
+
- 5 tasks created with correct properties
|
|
501
|
+
- All tasks linked to project
|
|
502
|
+
- No API errors
|
|
503
|
+
```
|
|
504
|
+
|
|
505
|
+
#### 3. So sánh Hiệu suất
|
|
506
|
+
|
|
507
|
+
**Mục tiêu:** Chứng minh skill cải thiện kết quả so với baseline.
|
|
508
|
+
|
|
509
|
+
Sử dụng các metrics từ phần Định nghĩa Tiêu chí Thành công. Đây là cách một so sánh có thể trông:
|
|
510
|
+
|
|
511
|
+
**So sánh Baseline:**
|
|
512
|
+
|
|
513
|
+
*Không có skill:*
|
|
514
|
+
- Người dùng cung cấp hướng dẫn mỗi lần
|
|
515
|
+
- 15 tin nhắn qua lại
|
|
516
|
+
- 3 lệnh gọi API thất bại cần thử lại
|
|
517
|
+
- 12,000 tokens tiêu thụ
|
|
518
|
+
|
|
519
|
+
*Với skill:*
|
|
520
|
+
- Thực thi quy trình tự động
|
|
521
|
+
- Chỉ 2 câu hỏi làm rõ
|
|
522
|
+
- 0 lệnh gọi API thất bại
|
|
523
|
+
- 6,000 tokens tiêu thụ
|
|
524
|
+
|
|
525
|
+
### Sử dụng skill-creator skill
|
|
526
|
+
|
|
527
|
+
Skill-creator skill - có sẵn trong Claude.ai qua plugin directory hoặc tải về cho Claude Code - có thể giúp bạn xây dựng và iteration trên skills. Nếu bạn có MCP server và biết 2-3 quy trình hàng đầu của mình, bạn có thể xây dựng và kiểm thử một skill hoạt động trong một buổi - thường trong 15-30 phút.
|
|
528
|
+
|
|
529
|
+
**Tạo skills:**
|
|
530
|
+
- Tạo skills từ mô tả ngôn ngữ tự nhiên
|
|
531
|
+
- Tạo SKILL.md đúng định dạng với frontmatter
|
|
532
|
+
- Đề xuất cụm từ kích hoạt và cấu trúc
|
|
533
|
+
|
|
534
|
+
**Reviewing skills:**
|
|
535
|
+
- Đánh dấu các vấn đề phổ biến (mô tả mơ hồ, thiếu triggers, vấn đề cấu trúc)
|
|
536
|
+
- Xác định rủi ro kích hoạt quá nhiều/quá ít
|
|
537
|
+
- Đề xuất test cases dựa trên mục đích stated của skill
|
|
538
|
+
|
|
539
|
+
**Cải tiến lặp lại:**
|
|
540
|
+
- Sau khi sử dụng skill và gặp edge cases hoặc failures, mang những ví dụ đó quay lại skill-creator
|
|
541
|
+
- Ví dụ: "Use the issues & solution identified in this chat to improve how the skill handles [specific edge case]"
|
|
542
|
+
|
|
543
|
+
**Cách sử dụng:**
|
|
544
|
+
```
|
|
545
|
+
"Use the skill-creator skill to help me build a skill for [your use case]"
|
|
546
|
+
```
|
|
547
|
+
|
|
548
|
+
Lưu ý: skill-creator giúp bạn thiết kế và cải tiến skills nhưng không thực hiện automated test suites hoặc tạo kết quả đánh giá định lượng.
|
|
549
|
+
|
|
550
|
+
### Iteration dựa trên phản hồi
|
|
551
|
+
|
|
552
|
+
Skills là tài liệu sống. Lên kế hoạch để iteration dựa trên:
|
|
553
|
+
|
|
554
|
+
**Tín hiệu kích hoạt thiếu (Undertriggering):**
|
|
555
|
+
- Skill không tải khi nên tải
|
|
556
|
+
- Người dùng bật thủ công
|
|
557
|
+
- Câu hỏi hỗ trợ về khi nào sử dụng
|
|
558
|
+
|
|
559
|
+
**Giải pháp:** Thêm chi tiết và sắc thái vào mô tả - điều này có thể bao gồm đặc biệt là các thuật ngữ kỹ thuật
|
|
560
|
+
|
|
561
|
+
**Tín hiệu kích hoạt quá nhiều (Overtriggering):**
|
|
562
|
+
- Skill tải cho các truy vấn không liên quan
|
|
563
|
+
- Người dùng tắt nó
|
|
564
|
+
- Nhầm lẫn về mục đích
|
|
565
|
+
|
|
566
|
+
**Giải pháp:** Thêm negative triggers, cụ thể hơn
|
|
567
|
+
|
|
568
|
+
**Vấn đề thực thi:**
|
|
569
|
+
- Kết quả không nhất quán
|
|
570
|
+
- Lệnh gọi API thất bại
|
|
571
|
+
- Cần người dùng sửa
|
|
572
|
+
|
|
573
|
+
**Giải pháp:** Cải tiến hướng dẫn, thêm xử lý lỗi
|
|
574
|
+
|
|
575
|
+
---
|
|
576
|
+
|
|
577
|
+
## Chương 4: Phân Phối và Chia Sẻ
|
|
578
|
+
|
|
579
|
+
Skills làm cho tích hợp MCP của bạn hoàn thiện hơn. Khi người dùng so sánh connectors, những cái có skills cung cấp con đường nhanh hơn đến giá trị, mang lại cho bạn lợi thế so với các alternatives chỉ có MCP.
|
|
580
|
+
|
|
581
|
+
### Mô hình phân phối hiện tại (January 2026)
|
|
582
|
+
|
|
583
|
+
**Cách người dùng cá nhân nhận skills:**
|
|
584
|
+
|
|
585
|
+
1. Tải thư mục skill
|
|
586
|
+
2. Nén thư mục (nếu cần)
|
|
587
|
+
3. Tải lên Claude.ai qua Settings > Capabilities > Skills
|
|
588
|
+
4. Hoặc đặt trong thư mục skills của Claude Code
|
|
589
|
+
|
|
590
|
+
**Skills cấp tổ chức:**
|
|
591
|
+
- Admins có thể triển khai skills toàn workspace (ra mắt December 18, 2025)
|
|
592
|
+
- Cập nhật tự động
|
|
593
|
+
- Quản lý tập trung
|
|
594
|
+
|
|
595
|
+
### Một tiêu chuẩn mở
|
|
596
|
+
|
|
597
|
+
Chúng tôi đã công bố Agent Skills như một tiêu chuẩn mở. Giống như MCP, chúng tôi tin rằng skills nên di động giữa các công cụ và nền tảng - cùng một skill nên hoạt động cho dù bạn đang sử dụng Claude hay các nền tảng AI khác. Tuy nhiên, một số skills được thiết kế để tận dụng đầy đủ khả năng của một nền tảng cụ thể; các tác giả có thể ghi chú điều này trong trường compatibility của skill. Chúng tôi đã cộng tác với các thành viên của hệ sinh thái về tiêu chuẩn, và chúng tôi hào hứng với việc áp dụng sớm.
|
|
598
|
+
|
|
599
|
+
### Sử dụng Skills qua API
|
|
600
|
+
|
|
601
|
+
Cho các trường hợp sử dụng lập trình - như xây dựng ứng dụng, agents, hoặc quy trình tự động tận dụng skills - API cung cấp quyền kiểm soát trực tiếp việc quản lý và thực thi skill.
|
|
602
|
+
|
|
603
|
+
**Khả năng chính:**
|
|
604
|
+
- Endpoint `/v1/skills` để liệt kê và quản lý skills
|
|
605
|
+
- Thêm skills vào yêu cầu Messages API qua tham số `container.skills`
|
|
606
|
+
- Version control và quản lý qua Claude Console
|
|
607
|
+
- Hoạt động với Claude Agent SDK để xây dựng custom agents
|
|
608
|
+
|
|
609
|
+
**Khi nào sử dụng Skills qua API vs. Claude.ai:**
|
|
610
|
+
|
|
611
|
+
| Trường hợp sử dụng | Nền tảng tốt nhất |
|
|
612
|
+
|-------------------|-------------------|
|
|
613
|
+
| Người dùng cuối tương tác trực tiếp với skills | Claude.ai / Claude Code |
|
|
614
|
+
| Kiểm thử thủ công và iteration trong phát triển | Claude.ai / Claude Code |
|
|
615
|
+
| Quy trình ad-hoc cá nhân | Claude.ai / Claude Code |
|
|
616
|
+
| Ứng dụng sử dụng skills lập trình | API |
|
|
617
|
+
| Triển khai production quy mô lớn | API |
|
|
618
|
+
| Pipelines tự động và hệ thống agent | API |
|
|
619
|
+
|
|
620
|
+
Lưu ý: Skills trong API yêu cầu Code Execution Tool beta, cung cấp môi trường bảo mà skills cần để chạy.
|
|
621
|
+
|
|
622
|
+
Để biết chi tiết triển khai, xem:
|
|
623
|
+
- Skills API Quickstart
|
|
624
|
+
- Create Custom Skills
|
|
625
|
+
- Skills in the Agent SDK
|
|
626
|
+
|
|
627
|
+
### Phương pháp Được khuyến nghị Hôm nay
|
|
628
|
+
|
|
629
|
+
Bắt đầu bằng việc host skill của bạn trên GitHub với repo công khai, README rõ ràng (cho khách truy cập - điều này tách biệt với thư mục skill của bạn, không nên chứa README.md), và ví dụ sử dụng với screenshots. Sau đó thêm một phần vào tài liệu MCP của bạn liên kết đến skill, giải thích tại sao sử dụng cả hai cùng nhau có giá trị, và cung cấp hướng dẫn bắt đầu nhanh.
|
|
630
|
+
|
|
631
|
+
1. **Host trên GitHub**
|
|
632
|
+
- Repo công khai cho open-source skills
|
|
633
|
+
- README rõ ràng với hướng dẫn cài đặt
|
|
634
|
+
- Ví dụ sử dụng và screenshots
|
|
635
|
+
|
|
636
|
+
2. **Tài liệu trong Repo MCP của bạn**
|
|
637
|
+
- Liên kết đến skills từ tài liệu MCP
|
|
638
|
+
- Giải thích giá trị của việc sử dụng cả hai cùng nhau
|
|
639
|
+
- Cung cấp hướng dẫn bắt đầu nhanh
|
|
640
|
+
|
|
641
|
+
3. **Tạo Hướng dẫn Cài đặt**
|
|
642
|
+
|
|
643
|
+
```markdown
|
|
644
|
+
# Cài đặt skill [Your Service]
|
|
645
|
+
|
|
646
|
+
1. Tải skill:
|
|
647
|
+
- Clone repo: `git clone https://github.com/yourcompany/skills`
|
|
648
|
+
- Hoặc tải ZIP từ Releases
|
|
649
|
+
|
|
650
|
+
2. Cài đặt trong Claude:
|
|
651
|
+
- Mở Claude.ai > Settings > Skills
|
|
652
|
+
- Click "Upload skill"
|
|
653
|
+
- Chọn thư mục skill (đã nén)
|
|
654
|
+
|
|
655
|
+
3. Kích hoạt skill:
|
|
656
|
+
- Bật skill [Your Service]
|
|
657
|
+
- Đảm bảo MCP server của bạn được kết nối
|
|
658
|
+
|
|
659
|
+
4. Test:
|
|
660
|
+
- Hỏi Claude: "Set up a new project in [Your Service]"
|
|
661
|
+
```
|
|
662
|
+
|
|
663
|
+
### Định vị Skill của bạn
|
|
664
|
+
|
|
665
|
+
Cách bạn mô tả skill xác định liệu người dùng có hiểu giá trị của nó và thực sự thử nó hay không. Khi viết về skill - trong README, tài liệu, hoặc marketing - giữ các nguyên tắc này trong đầu.
|
|
666
|
+
|
|
667
|
+
**Tập trung vào kết quả, không phải tính năng:**
|
|
668
|
+
|
|
669
|
+
✅ **Tốt:**
|
|
670
|
+
> "Skill ProjectHub cho phép teams thiết lập không gian làm việc dự án hoàn chỉnh trong vài giây — bao gồm pages, databases, và templates — thay vì dành 30 phút cho thiết lập thủ công."
|
|
671
|
+
|
|
672
|
+
❌ **Xấu:**
|
|
673
|
+
> "Skill ProjectHub là một thư mục chứa YAML frontmatter và Markdown instructions gọi các công cụ MCP server của chúng tôi."
|
|
674
|
+
|
|
675
|
+
**Nổi bật câu chuyện MCP + skills:**
|
|
676
|
+
> "MCP server của chúng tôi cung cấp cho Claude quyền truy cập các dự án Linear của bạn. Skills của chúng tôi dạy Claude quy trình lập kế hoạch sprint của team bạn. Cùng nhau, chúng cho phép quản lý dự án được AI hỗ trợ."
|
|
677
|
+
|
|
678
|
+
---
|
|
679
|
+
|
|
680
|
+
## Chương 5: Các Mẫu và Xử Lý Sự Cố
|
|
681
|
+
|
|
682
|
+
Các mẫu này xuất phát từ skills được tạo bởi những người dùng sớm và các teams nội bộ. Chúng đại diện cho các cách tiếp cận phổ biến mà chúng tôi đã thấy hoạt động tốt, không phải templates bắt buộc.
|
|
683
|
+
|
|
684
|
+
### Chọn cách tiếp cận của bạn: Problem-first vs. Tool-first
|
|
685
|
+
|
|
686
|
+
Hãy nghĩ về Home Depot. Bạn có thể vào với một vấn đề - "Tôi cần sửa tủ bếp" - và một nhân viên chỉ bạn đến công cụ phù hợp. Hoặc bạn có thể chọn một chiếc máy khoan mới và hỏi cách sử dụng nó cho công việc cụ thể của bạn.
|
|
687
|
+
|
|
688
|
+
Skills hoạt động tương tự:
|
|
689
|
+
|
|
690
|
+
- **Problem-first:** "Tôi cần thiết lập không gian làm việc dự án" → Skill của bạn điều phối các lệnh gọi MCP đúng theo đúng trình tự. Người dùng mô tả kết quả; skill xử lý công cụ.
|
|
691
|
+
- **Tool-first:** "Tôi đã kết nối Notion MCP" → Skill của bạn dạy Claude các quy trình tối ưu và best practices. Người dùng có quyền truy cập; skill cung cấp chuyên môn.
|
|
692
|
+
|
|
693
|
+
Hầu hết skills nghiêng về một hướng. Biết khung nào phù hợp với trường hợp sử dụng của bạn giúp bạn chọn mẫu đúng bên dưới.
|
|
694
|
+
|
|
695
|
+
### Mẫu 1: Điều phối Quy trình Tuần tự
|
|
696
|
+
|
|
697
|
+
**Sử dụng khi:** Người dùng cần các quy trình nhiều bước theo thứ tự cụ thể.
|
|
698
|
+
|
|
699
|
+
**Cấu trúc ví dụ:**
|
|
700
|
+
|
|
701
|
+
```markdown
|
|
702
|
+
## Workflow: Onboard New Customer
|
|
703
|
+
|
|
704
|
+
### Bước 1: Create Account
|
|
705
|
+
Gọi MCP tool: `create_customer`
|
|
706
|
+
Parameters: name, email, company
|
|
707
|
+
|
|
708
|
+
### Bước 2: Setup Payment
|
|
709
|
+
Gọi MCP tool: `setup_payment_method`
|
|
710
|
+
Chờ: payment method verification
|
|
711
|
+
|
|
712
|
+
### Bước 3: Create Subscription
|
|
713
|
+
Gọi MCP tool: `create_subscription`
|
|
714
|
+
Parameters: plan_id, customer_id (từ Bước 1)
|
|
715
|
+
|
|
716
|
+
### Bước 4: Send Welcome Email
|
|
717
|
+
Gọi MCP tool: `send_email`
|
|
718
|
+
Template: welcome_email_template
|
|
719
|
+
```
|
|
720
|
+
|
|
721
|
+
**Kỹ thuật chính:**
|
|
722
|
+
- Thứ tự bước rõ ràng
|
|
723
|
+
- Dependencies giữa các bước
|
|
724
|
+
- Validation tại mỗi giai đoạn
|
|
725
|
+
- Hướng dẫn rollback cho failures
|
|
726
|
+
|
|
727
|
+
### Mẫu 2: Điều phối Multi-MCP
|
|
728
|
+
|
|
729
|
+
**Sử dụng khi:** Quy trình span nhiều dịch vụ.
|
|
730
|
+
|
|
731
|
+
**Ví dụ:** Chuyển giao từ thiết kế sang phát triển
|
|
732
|
+
|
|
733
|
+
```markdown
|
|
734
|
+
### Phase 1: Design Export (Figma MCP)
|
|
735
|
+
1. Export design assets từ Figma
|
|
736
|
+
2. Generate design specifications
|
|
737
|
+
3. Tạo asset manifest
|
|
738
|
+
|
|
739
|
+
### Phase 2: Asset Storage (Drive MCP)
|
|
740
|
+
1. Tạo project folder trong Drive
|
|
741
|
+
2. Upload tất cả assets
|
|
742
|
+
3. Generate shareable links
|
|
743
|
+
|
|
744
|
+
### Phase 3: Task Creation (Linear MCP)
|
|
745
|
+
1. Tạo development tasks
|
|
746
|
+
2. Đính kèm asset links vào tasks
|
|
747
|
+
3. Giao cho engineering team
|
|
748
|
+
|
|
749
|
+
### Phase 4: Notification (Slack MCP)
|
|
750
|
+
1. Post handoff summary đến #engineering
|
|
751
|
+
2. Bao gồm asset links và task references
|
|
752
|
+
```
|
|
753
|
+
|
|
754
|
+
**Kỹ thuật chính:**
|
|
755
|
+
- Phân tách phase rõ ràng
|
|
756
|
+
- Truyền dữ liệu giữa các MCPs
|
|
757
|
+
- Validation trước khi chuyển sang phase tiếp theo
|
|
758
|
+
- Xử lý lỗi tập trung
|
|
759
|
+
|
|
760
|
+
### Mẫu 3: Cải tiến Lặp lại
|
|
761
|
+
|
|
762
|
+
**Sử dụng khi:** Chất lượng output được cải thiện với iteration.
|
|
763
|
+
|
|
764
|
+
**Ví dụ:** Tạo báo cáo
|
|
765
|
+
|
|
766
|
+
```markdown
|
|
767
|
+
## Iterative Report Creation
|
|
768
|
+
|
|
769
|
+
### Initial Draft
|
|
770
|
+
1. Fetch data via MCP
|
|
771
|
+
2. Generate first draft report
|
|
772
|
+
3. Save to temporary file
|
|
773
|
+
|
|
774
|
+
### Quality Check
|
|
775
|
+
1. Run validation script: `scripts/check_report.py`
|
|
776
|
+
2. Identify issues:
|
|
777
|
+
- Missing sections
|
|
778
|
+
- Inconsistent formatting
|
|
779
|
+
- Data validation errors
|
|
780
|
+
|
|
781
|
+
### Refinement Loop
|
|
782
|
+
1. Address each identified issue
|
|
783
|
+
2. Regenerate affected sections
|
|
784
|
+
3. Re-validate
|
|
785
|
+
4. Repeat until quality threshold met
|
|
786
|
+
|
|
787
|
+
### Finalization
|
|
788
|
+
1. Apply final formatting
|
|
789
|
+
2. Generate summary
|
|
790
|
+
3. Save final version
|
|
791
|
+
```
|
|
792
|
+
|
|
793
|
+
**Kỹ thuật chính:**
|
|
794
|
+
- Tiêu chí chất lượng rõ ràng
|
|
795
|
+
- Cải tiến lặp lại
|
|
796
|
+
- Validation scripts
|
|
797
|
+
- Biết khi nào dừng iteration
|
|
798
|
+
|
|
799
|
+
### Mẫu 4: Lựa chọn Công cụ Nhận biết Context
|
|
800
|
+
|
|
801
|
+
**Sử dụng khi:** Cùng kết quả, công cụ khác nhau tùy thuộc context.
|
|
802
|
+
|
|
803
|
+
**Ví dụ:** Lưu trữ file
|
|
804
|
+
|
|
805
|
+
```markdown
|
|
806
|
+
## Smart File Storage
|
|
807
|
+
|
|
808
|
+
### Decision Tree
|
|
809
|
+
1. Check file type and size
|
|
810
|
+
2. Determine best storage location:
|
|
811
|
+
- Large files (>10MB): Use cloud storage MCP
|
|
812
|
+
- Collaborative docs: Use Notion/Docs MCP
|
|
813
|
+
- Code files: Use GitHub MCP
|
|
814
|
+
- Temporary files: Use local storage
|
|
815
|
+
|
|
816
|
+
### Execute Storage
|
|
817
|
+
Based on decision:
|
|
818
|
+
- Call appropriate MCP tool
|
|
819
|
+
- Apply service-specific metadata
|
|
820
|
+
- Generate access link
|
|
821
|
+
|
|
822
|
+
### Provide Context to User
|
|
823
|
+
Explain why that storage was chosen
|
|
824
|
+
```
|
|
825
|
+
|
|
826
|
+
**Kỹ thuật chính:**
|
|
827
|
+
- Tiêu chí quyết định rõ ràng
|
|
828
|
+
- Fallback options
|
|
829
|
+
- Minh bạch về các lựa chọn
|
|
830
|
+
|
|
831
|
+
### Mẫu 5: Trí tuệ Domain-Specific
|
|
832
|
+
|
|
833
|
+
**Sử dụng khi:** Skill của bạn bổ sung kiến thức chuyên môn vượt quá quyền truy cập công cụ.
|
|
834
|
+
|
|
835
|
+
**Ví dụ:** Tuân thủ tài chính
|
|
836
|
+
|
|
837
|
+
```markdown
|
|
838
|
+
## Payment Processing with Compliance
|
|
839
|
+
|
|
840
|
+
### Before Processing (Compliance Check)
|
|
841
|
+
1. Fetch transaction details via MCP
|
|
842
|
+
2. Apply compliance rules:
|
|
843
|
+
- Check sanctions lists
|
|
844
|
+
- Verify jurisdiction allowances
|
|
845
|
+
- Assess risk level
|
|
846
|
+
3. Document compliance decision
|
|
847
|
+
|
|
848
|
+
### Processing
|
|
849
|
+
IF compliance passed:
|
|
850
|
+
- Call payment processing MCP tool
|
|
851
|
+
- Apply appropriate fraud checks
|
|
852
|
+
- Process transaction
|
|
853
|
+
ELSE:
|
|
854
|
+
- Flag for review
|
|
855
|
+
- Create compliance case
|
|
856
|
+
|
|
857
|
+
### Audit Trail
|
|
858
|
+
- Log all compliance checks
|
|
859
|
+
- Record processing decisions
|
|
860
|
+
- Generate audit report
|
|
861
|
+
```
|
|
862
|
+
|
|
863
|
+
**Kỹ thuật chính:**
|
|
864
|
+
- Chuyên môn domain được nhúng trong logic
|
|
865
|
+
- Tuân thủ trước khi hành động
|
|
866
|
+
- Tài liệu toàn diện
|
|
867
|
+
- Quản trị rõ ràng
|
|
868
|
+
|
|
869
|
+
---
|
|
870
|
+
|
|
871
|
+
## Xử Lý Sự Cố
|
|
872
|
+
|
|
873
|
+
### Skill không tải lên được
|
|
874
|
+
|
|
875
|
+
**Lỗi:** "Could not find SKILL.md in uploaded folder"
|
|
876
|
+
|
|
877
|
+
- **Nguyên nhân:** File không đặt tên chính xác SKILL.md
|
|
878
|
+
- **Giải pháp:**
|
|
879
|
+
- Đổi tên thành SKILL.md (phân biệt hoa thường)
|
|
880
|
+
- Xác minh với: `ls -la` sẽ hiển thị SKILL.md
|
|
881
|
+
|
|
882
|
+
**Lỗi:** "Invalid frontmatter"
|
|
883
|
+
|
|
884
|
+
- **Nguyên nhân:** Vấn đề định dạng YAML
|
|
885
|
+
- **Lỗi phổ biến:**
|
|
886
|
+
|
|
887
|
+
```yaml
|
|
888
|
+
# Sai - thiếu delimiters
|
|
889
|
+
name: my-skill
|
|
890
|
+
description: Does things
|
|
891
|
+
|
|
892
|
+
# Sai - quotes chưa đóng
|
|
893
|
+
name: my-skill
|
|
894
|
+
description: "Does things
|
|
895
|
+
|
|
896
|
+
# Đúng
|
|
897
|
+
---
|
|
898
|
+
name: my-skill
|
|
899
|
+
description: Does things
|
|
900
|
+
---
|
|
901
|
+
```
|
|
902
|
+
|
|
903
|
+
**Lỗi:** "Invalid skill name"
|
|
904
|
+
|
|
905
|
+
- **Nguyên nhân:** Tên có dấu cách hoặc viết hoa
|
|
906
|
+
|
|
907
|
+
```yaml
|
|
908
|
+
# Sai
|
|
909
|
+
name: My Cool Skill
|
|
910
|
+
|
|
911
|
+
# Đúng
|
|
912
|
+
name: my-cool-skill
|
|
913
|
+
```
|
|
914
|
+
|
|
915
|
+
### Skill không kích hoạt
|
|
916
|
+
|
|
917
|
+
**Triệu chứng:** Skill không bao giờ tự động tải
|
|
918
|
+
|
|
919
|
+
**Sửa:**
|
|
920
|
+
Sửa trường description của bạn. Xem phần Trường Description để xem ví dụ tốt/xấu.
|
|
921
|
+
|
|
922
|
+
**Checklist nhanh:**
|
|
923
|
+
- Có quá mơ hồ không? ("Helps with projects" sẽ không hoạt động)
|
|
924
|
+
- Có bao gồm cụm từ kích hoạt mà người dùng thực sự nói không?
|
|
925
|
+
- Có đề cập các loại file liên quan nếu áp dụng không?
|
|
926
|
+
|
|
927
|
+
**Cách debug:**
|
|
928
|
+
Hỏi Claude: "When would you use the [skill name] skill?" Claude sẽ trích dẫn mô tả. Điều chỉnh dựa trên những gì còn thiếu.
|
|
929
|
+
|
|
930
|
+
### Skill kích hoạt quá thường xuyên
|
|
931
|
+
|
|
932
|
+
**Triệu chứng:** Skill tải cho các truy vấn không liên quan
|
|
933
|
+
|
|
934
|
+
**Giải pháp:**
|
|
935
|
+
|
|
936
|
+
1. **Thêm negative triggers**
|
|
937
|
+
```yaml
|
|
938
|
+
description: Advanced data analysis for CSV files. Use for
|
|
939
|
+
statistical modeling, regression, clustering. Do NOT use for
|
|
940
|
+
simple data exploration (use data-viz skill instead).
|
|
941
|
+
```
|
|
942
|
+
|
|
943
|
+
2. **Cụ thể hơn**
|
|
944
|
+
```yaml
|
|
945
|
+
# Quá rộng
|
|
946
|
+
description: Processes documents
|
|
947
|
+
|
|
948
|
+
# Cụ thể hơn
|
|
949
|
+
description: Processes PDF legal documents for contract review
|
|
950
|
+
```
|
|
951
|
+
|
|
952
|
+
3. **Làm rõ phạm vi**
|
|
953
|
+
```yaml
|
|
954
|
+
description: PayFlow payment processing for e-commerce. Use
|
|
955
|
+
specifically for online payment workflows, not for general
|
|
956
|
+
financial queries.
|
|
957
|
+
```
|
|
958
|
+
|
|
959
|
+
### Vấn đề kết nối MCP
|
|
960
|
+
|
|
961
|
+
**Triệu chứng:** Skill tải nhưng lệnh gọi MCP thất bại
|
|
962
|
+
|
|
963
|
+
**Checklist:**
|
|
964
|
+
|
|
965
|
+
1. **Xác minh MCP server được kết nối**
|
|
966
|
+
- Claude.ai: Settings > Extensions > [Your Service]
|
|
967
|
+
- Nên hiển thị trạng thái "Connected"
|
|
968
|
+
|
|
969
|
+
2. **Kiểm tra xác thực**
|
|
970
|
+
- API keys hợp lệ và chưa hết hạn
|
|
971
|
+
- Permissions/scopes phù hợp được cấp
|
|
972
|
+
- OAuth tokens được refresh
|
|
973
|
+
|
|
974
|
+
3. **Test MCP độc lập**
|
|
975
|
+
- Yêu cầu Claude gọi MCP trực tiếp (không có skill)
|
|
976
|
+
- "Use [Service] MCP to fetch my projects"
|
|
977
|
+
- Nếu thất bại, vấn đề là MCP không phải skill
|
|
978
|
+
|
|
979
|
+
4. **Xác minh tên công cụ**
|
|
980
|
+
- Skill tham chiếu đúng tên MCP tool
|
|
981
|
+
- Kiểm tra tài liệu MCP server
|
|
982
|
+
- Tên công cụ phân biệt hoa thường
|
|
983
|
+
|
|
984
|
+
### Hướng dẫn không được tuân theo
|
|
985
|
+
|
|
986
|
+
**Triệu chứng:** Skill tải nhưng Claude không tuân theo hướng dẫn
|
|
987
|
+
|
|
988
|
+
**Nguyên nhân phổ biến:**
|
|
989
|
+
|
|
990
|
+
1. **Hướng dẫn quá dài**
|
|
991
|
+
- Giữ hướng dẫn ngắn gọn
|
|
992
|
+
- Sử dụng bullet points và numbered lists
|
|
993
|
+
- Di chuyển tài liệu tham chiếu chi tiết vào file riêng
|
|
994
|
+
|
|
995
|
+
2. **Hướng dẫn bị chôn**
|
|
996
|
+
- Đặt hướng dẫn quan trọng ở trên cùng
|
|
997
|
+
- Sử dụng headers ## Important hoặc ## Critical
|
|
998
|
+
- Lặp lại các điểm chính nếu cần
|
|
999
|
+
|
|
1000
|
+
3. **Ngôn ngữ mơ hồ**
|
|
1001
|
+
|
|
1002
|
+
```yaml
|
|
1003
|
+
# Xấu
|
|
1004
|
+
Make sure to validate things properly
|
|
1005
|
+
|
|
1006
|
+
# Tốt
|
|
1007
|
+
CRITICAL: Before calling create_project, verify:
|
|
1008
|
+
- Project name is non-empty
|
|
1009
|
+
- At least one team member assigned
|
|
1010
|
+
- Start date is not in the past
|
|
1011
|
+
```
|
|
1012
|
+
|
|
1013
|
+
> **Kỹ thuật nâng cao:** Cho các validation quan trọng, cân nhắc đóng gói một script thực hiện các kiểm tra theo chương trình thay vì dựa vào hướng dẫn bằng ngôn ngữ. Code là deterministic; việc diễn giải ngôn ngữ thì không. Xem Office skills để biết ví dụ về mẫu này.
|
|
1014
|
+
|
|
1015
|
+
4. **Model "lười"** - Thêm khuyến khích rõ ràng:
|
|
1016
|
+
```markdown
|
|
1017
|
+
## Performance Notes
|
|
1018
|
+
- Take your time to do this thoroughly
|
|
1019
|
+
- Quality is more important than speed
|
|
1020
|
+
- Do not skip validation steps
|
|
1021
|
+
```
|
|
1022
|
+
|
|
1023
|
+
Lưu ý: Thêm điều này vào user prompts hiệu quả hơn trong SKILL.md
|
|
1024
|
+
|
|
1025
|
+
### Vấn đề Large Context
|
|
1026
|
+
|
|
1027
|
+
**Triệu chứng:** Skill có vẻ chậm hoặc responses suy giảm
|
|
1028
|
+
|
|
1029
|
+
**Nguyên nhân:**
|
|
1030
|
+
- Nội dung skill quá lớn
|
|
1031
|
+
- Quá nhiều skills được bật cùng lúc
|
|
1032
|
+
- Tất cả nội dung được tải thay vì progressive disclosure
|
|
1033
|
+
|
|
1034
|
+
**Giải pháp:**
|
|
1035
|
+
|
|
1036
|
+
1. **Tối ưu kích thước SKILL.md**
|
|
1037
|
+
- Di chuyển tài liệu chi tiết vào references/
|
|
1038
|
+
- Liên kết đến references thay vì inline
|
|
1039
|
+
- Giữ SKILL.md dưới 5,000 từ
|
|
1040
|
+
|
|
1041
|
+
2. **Giảm số skills được bật**
|
|
1042
|
+
- Đánh giá nếu bạn có hơn 20-50 skills được bật cùng lúc
|
|
1043
|
+
- Khuyến nghị bật chọn lọc
|
|
1044
|
+
- Cân nhắc "packs" cho các khả năng liên quan
|
|
1045
|
+
|
|
1046
|
+
---
|
|
1047
|
+
|
|
1048
|
+
## Chương 6: Tài Nguyên và Tham Khảo
|
|
1049
|
+
|
|
1050
|
+
Nếu bạn đang xây dựng skill đầu tiên, hãy bắt đầu với Best Practices Guide, sau đó tham khảo API docs khi cần.
|
|
1051
|
+
|
|
1052
|
+
### Tài liệu Chính thức
|
|
1053
|
+
|
|
1054
|
+
**Anthropic Resources:**
|
|
1055
|
+
- Best Practices Guide
|
|
1056
|
+
- Skills Documentation
|
|
1057
|
+
- API Reference
|
|
1058
|
+
- MCP Documentation
|
|
1059
|
+
|
|
1060
|
+
**Blog Posts:**
|
|
1061
|
+
- Introducing Agent Skills
|
|
1062
|
+
- Engineering Blog: Equating Agents for the Real World
|
|
1063
|
+
- Skills Explained
|
|
1064
|
+
- How to Create Skills for Claude
|
|
1065
|
+
- Building Skills for Claude Code
|
|
1066
|
+
- Improving Frontend Design through Skills
|
|
1067
|
+
|
|
1068
|
+
### Skills mẫu
|
|
1069
|
+
|
|
1070
|
+
**Kho skills công khai:**
|
|
1071
|
+
- GitHub: anthropics/skills
|
|
1072
|
+
- Chứa các skills được tạo bởi Anthropic mà bạn có thể tùy chỉnh
|
|
1073
|
+
|
|
1074
|
+
### Công cụ và Tiện ích
|
|
1075
|
+
|
|
1076
|
+
**skill-creator skill:**
|
|
1077
|
+
- Được tích hợp sẵn trong Claude.ai và có sẵn cho Claude Code
|
|
1078
|
+
- Có thể tạo skills từ mô tả
|
|
1079
|
+
- Reviews và đưa ra đề xuất
|
|
1080
|
+
- Sử dụng: "Help me build a skill using skill-creator"
|
|
1081
|
+
|
|
1082
|
+
**Validation:**
|
|
1083
|
+
- skill-creator có thể đánh giá skills của bạn
|
|
1084
|
+
- Hỏi: "Review this skill and suggest improvements"
|
|
1085
|
+
|
|
1086
|
+
### Nhận Hỗ trợ
|
|
1087
|
+
|
|
1088
|
+
**Cho câu hỏi kỹ thuật:**
|
|
1089
|
+
- Câu hỏi chung: Community forums tại Claude Developers Discord
|
|
1090
|
+
|
|
1091
|
+
**Cho báo cáo lỗi:**
|
|
1092
|
+
- GitHub Issues: anthropics/skills/issues
|
|
1093
|
+
- Bao gồm: Tên skill, thông báo lỗi, các bước để tái tạo
|
|
1094
|
+
|
|
1095
|
+
---
|
|
1096
|
+
|
|
1097
|
+
## Phụ lục A: Checklist Nhanh
|
|
1098
|
+
|
|
1099
|
+
Sử dụng checklist này để validate skill của bạn trước và sau khi tải lên. Nếu bạn muốn bắt đầu nhanh hơn, hãy sử dụng skill-creator skill để tạo bản nháp đầu tiên, sau đó chạy qua danh sách này để đảm bảo bạn không bỏ sót gì.
|
|
1100
|
+
|
|
1101
|
+
**Trước khi bắt đầu**
|
|
1102
|
+
- [ ] Xác định 2-3 trường hợp sử dụng cụ thể
|
|
1103
|
+
- [ ] Xác định công cụ (built-in hoặc MCP)
|
|
1104
|
+
- [ ] Xem lại hướng dẫn này và ví dụ skills
|
|
1105
|
+
- [ ] Lên kế hoạch cấu trúc thư mục
|
|
1106
|
+
|
|
1107
|
+
**Trong quá trình phát triển**
|
|
1108
|
+
- [ ] Thư mục đặt tên bằng kebab-case
|
|
1109
|
+
- [ ] File SKILL.md tồn tại (đúng chính tả)
|
|
1110
|
+
- [ ] YAML frontmatter có delimiters `---`
|
|
1111
|
+
- [ ] Trường name: kebab-case, không dấu cách, không viết hoa
|
|
1112
|
+
- [ ] Mô tả bao gồm WHAT và WHEN
|
|
1113
|
+
- [ ] Không có thẻ XML (`<` `>`) ở bất kỳ đâu
|
|
1114
|
+
- [ ] Hướng dẫn rõ ràng và có thể hành động
|
|
1115
|
+
- [ ] Bao gồm xử lý lỗi
|
|
1116
|
+
- [ ] Cung cấp ví dụ
|
|
1117
|
+
- [ ] References được liên kết rõ ràng
|
|
1118
|
+
|
|
1119
|
+
**Trước khi tải lên**
|
|
1120
|
+
- [ ] Test kích hoạt trên các tác vụ rõ ràng
|
|
1121
|
+
- [ ] Test kích hoạt trên các yêu cầu được diễn giải lại
|
|
1122
|
+
- [ ] Xác minh không kích hoạt trên các chủ đề không liên quan
|
|
1123
|
+
- [ ] Functional tests pass
|
|
1124
|
+
- [ ] Tích hợp công cụ hoạt động (nếu áp dụng)
|
|
1125
|
+
- [ ] Nén thành file .zip
|
|
1126
|
+
|
|
1127
|
+
**Sau khi tải lên**
|
|
1128
|
+
- [ ] Test trong các cuộc trò chuyện thực
|
|
1129
|
+
- [ ] Theo dõi under/over-triggering
|
|
1130
|
+
- [ ] Thu thập phản hồi người dùng
|
|
1131
|
+
- [ ] Iteration trên mô tả và hướng dẫn
|
|
1132
|
+
- [ ] Cập nhật version trong metadata
|
|
1133
|
+
|
|
1134
|
+
---
|
|
1135
|
+
|
|
1136
|
+
## Phụ lục B: YAML Frontmatter
|
|
1137
|
+
|
|
1138
|
+
### Các trường bắt buộc
|
|
1139
|
+
|
|
1140
|
+
```yaml
|
|
1141
|
+
---
|
|
1142
|
+
name: skill-name-in-kebab-case
|
|
1143
|
+
description: What it does and when to use it. Include specific
|
|
1144
|
+
trigger phrases.
|
|
1145
|
+
---
|
|
1146
|
+
```
|
|
1147
|
+
|
|
1148
|
+
### Tất cả các trường tùy chọn
|
|
1149
|
+
|
|
1150
|
+
```yaml
|
|
1151
|
+
name: skill-name
|
|
1152
|
+
description: [required description]
|
|
1153
|
+
license: MIT # Optional: License for open-source
|
|
1154
|
+
allowed-tools: "Bash(python:*) Bash(npm:*) WebFetch" # Optional: Restrict tool access
|
|
1155
|
+
metadata: # Optional: Custom fields
|
|
1156
|
+
author: Company Name
|
|
1157
|
+
version: 1.0.0
|
|
1158
|
+
mcp-server: server-name
|
|
1159
|
+
category: productivity
|
|
1160
|
+
tags: [project-management, automation]
|
|
1161
|
+
documentation: https://example.com/docs
|
|
1162
|
+
support: support@example.com
|
|
1163
|
+
```
|
|
1164
|
+
|
|
1165
|
+
### Ghi chú bảo mật
|
|
1166
|
+
|
|
1167
|
+
**Cho phép:**
|
|
1168
|
+
- Bất kỳ loại YAML tiêu chuẩn nào (strings, numbers, booleans, lists, objects)
|
|
1169
|
+
- Trường metadata tùy chỉnh
|
|
1170
|
+
- Mô tả dài (đến 1024 ký tự)
|
|
1171
|
+
|
|
1172
|
+
**Cấm:**
|
|
1173
|
+
- Dấu ngoặc góc XML (`<` `>`) - hạn chế bảo mật
|
|
1174
|
+
- Thực thi code trong YAML (sử dụng safe YAML parsing)
|
|
1175
|
+
- Skills có tên tiền tố "claude" hoặc "anthropic" (đã đặt trước)
|
|
1176
|
+
|
|
1177
|
+
---
|
|
1178
|
+
|
|
1179
|
+
## Phụ lục C: Ví Dụ Skills Hoàn Chỉnh
|
|
1180
|
+
|
|
1181
|
+
Để xem các skills production-ready đầy đủ minh họa các mẫu trong hướng dẫn này:
|
|
1182
|
+
- **Document Skills** - Tạo PDF, DOCX, PPTX, XLSX
|
|
1183
|
+
- **Example Skills** - Các mẫu quy trình khác nhau
|
|
1184
|
+
- **Partner Skills Directory** - Xem skills từ các đối tác như Asana, Atlassian, Canva, Figma, Sentry, Zapier, và nhiều hơn nữa
|
|
1185
|
+
|
|
1186
|
+
Các repositories này được cập nhật thường xuyên và bao gồm các ví dụ bổ sung ngoài những gì được đề cập ở đây. Clone chúng, sửa đổi cho trường hợp sử dụng của bạn, và sử dụng chúng làm templates.
|
|
1187
|
+
|
|
1188
|
+
---
|
|
1189
|
+
|
|
1190
|
+
*Tài liệu này được dịch từ "The Complete Guide to Building Skills for Claude" của Anthropic.*
|