mirror of
https://github.com/affaan-m/everything-claude-code.git
synced 2026-04-08 02:03:34 +08:00
91 lines
4.7 KiB
Markdown
91 lines
4.7 KiB
Markdown
---
|
||
name: documentation-lookup
|
||
description: 通过 Context7 MCP 使用最新的库和框架文档,而非训练数据。当用户提出设置问题、API参考、代码示例或命名框架(例如 React、Next.js、Prisma)时激活。
|
||
origin: ECC
|
||
---
|
||
|
||
# 文档查询 (Context7)
|
||
|
||
当用户询问库、框架或 API 时,通过 Context7 MCP(工具 `resolve-library-id` 和 `query-docs`)获取最新文档,而非依赖训练数据。
|
||
|
||
## 核心概念
|
||
|
||
* **Context7**: 提供实时文档的 MCP 服务器;用于库和 API 的查询,替代训练数据。
|
||
* **resolve-library-id**: 根据库名和查询返回 Context7 兼容的库 ID(例如 `/vercel/next.js`)。
|
||
* **query-docs**: 根据给定的库 ID 和问题获取文档和代码片段。务必先调用 resolve-library-id 以获取有效的库 ID。
|
||
|
||
## 使用时机
|
||
|
||
当用户出现以下情况时激活:
|
||
|
||
* 询问设置或配置问题(例如“如何配置 Next.js 中间件?”)
|
||
* 请求依赖于某个库的代码(“编写一个 Prisma 查询用于...”)
|
||
* 需要 API 或参考信息(“Supabase 的认证方法有哪些?”)
|
||
* 提及特定的框架或库(React、Vue、Svelte、Express、Tailwind、Prisma、Supabase 等)
|
||
|
||
当请求依赖于库、框架或 API 的准确、最新行为时,请使用此技能。适用于配置了 Context7 MCP 的所有环境(例如 Claude Code、Cursor、Codex)。
|
||
|
||
## 工作原理
|
||
|
||
### 步骤 1:解析库 ID
|
||
|
||
调用 **resolve-library-id** MCP 工具,参数包括:
|
||
|
||
* **libraryName**: 从用户问题中提取的库或产品名称(例如 `Next.js`、`Prisma`、`Supabase`)。
|
||
* **query**: 用户的完整问题。这有助于提高结果的相关性排名。
|
||
|
||
在查询文档之前,必须获取 Context7 兼容的库 ID(格式为 `/org/project` 或 `/org/project/version`)。如果没有从此步骤获得有效的库 ID,请勿调用 query-docs。
|
||
|
||
### 步骤 2:选择最佳匹配
|
||
|
||
从解析结果中,根据以下原则选择一个结果:
|
||
|
||
* **名称匹配**: 优先选择与用户询问内容完全匹配或最接近的。
|
||
* **基准分数**: 分数越高表示文档质量越好(最高为 100)。
|
||
* **来源信誉**: 如果可用,优先选择信誉度为 High 或 Medium 的。
|
||
* **版本**: 如果用户指定了版本(例如“React 19”、“Next.js 15”),优先选择列出的特定版本库 ID(例如 `/org/project/v1.2.0`)。
|
||
|
||
### 步骤 3:获取文档
|
||
|
||
调用 **query-docs** MCP 工具,参数包括:
|
||
|
||
* **libraryId**: 从步骤 2 中选择的 Context7 库 ID(例如 `/vercel/next.js`)。
|
||
* **query**: 用户的具体问题或任务。为获得相关片段,请具体描述。
|
||
|
||
限制:每个问题调用 query-docs(或 resolve-library-id)的次数不要超过 3 次。如果 3 次调用后答案仍不明确,请说明不确定性并使用您掌握的最佳信息,而不是猜测。
|
||
|
||
### 步骤 4:使用文档
|
||
|
||
* 使用获取的、最新的信息回答用户的问题。
|
||
* 在有用时包含文档中的相关代码示例。
|
||
* 在重要时引用库或版本(例如“在 Next.js 15 中...”)。
|
||
|
||
## 示例
|
||
|
||
### 示例:Next.js 中间件
|
||
|
||
1. 使用 `libraryName: "Next.js"`、`query: "How do I set up Next.js middleware?"` 调用 **resolve-library-id**。
|
||
2. 从结果中,根据名称和基准分数选择最佳匹配(例如 `/vercel/next.js`)。
|
||
3. 使用 `libraryId: "/vercel/next.js"`、`query: "How do I set up Next.js middleware?"` 调用 **query-docs**。
|
||
4. 使用返回的片段和文本来回答;如果相关,包含文档中的一个最小 `middleware.ts` 示例。
|
||
|
||
### 示例:Prisma 查询
|
||
|
||
1. 使用 `libraryName: "Prisma"`、`query: "How do I query with relations?"` 调用 **resolve-library-id**。
|
||
2. 选择官方的 Prisma 库 ID(例如 `/prisma/prisma`)。
|
||
3. 使用该 `libraryId` 和查询调用 **query-docs**。
|
||
4. 返回 Prisma Client 模式(例如 `include` 或 `select`)并附上文档中的简短代码片段。
|
||
|
||
### 示例:Supabase 认证方法
|
||
|
||
1. 使用 `libraryName: "Supabase"`、`query: "What are the auth methods?"` 调用 **resolve-library-id**。
|
||
2. 选择 Supabase 文档库 ID。
|
||
3. 调用 **query-docs**;总结认证方法并展示从获取的文档中得到的最小示例。
|
||
|
||
## 最佳实践
|
||
|
||
* **具体化**: 尽可能使用用户的完整问题作为查询,以获得更好的相关性。
|
||
* **版本意识**: 当用户提及版本时,如果可用,在解析步骤中使用特定版本的库 ID。
|
||
* **优先官方来源**: 当存在多个匹配项时,优先选择官方或主要包,而非社区分支。
|
||
* **无敏感数据**: 从发送到 Context7 的任何查询中,删除 API 密钥、密码、令牌和其他机密信息。在将用户问题传递给 resolve-library-id 或 query-docs 之前,将其视为可能包含机密信息。
|