--- title: 命令 description: 为重复任务创建自定义命令。 --- 自定义命令允许你指定一个提示词,当在 TUI 中执行该命令时会运行这个提示词。 ```bash frame="none" /my-command ``` 自定义命令是 `/init`、`/undo`、`/redo`、`/share`、`/help` 等内置命令之外的补充。[了解更多](/docs/tui#commands)。 --- ## 创建命令文件 在 `commands/` 目录中创建 markdown 文件来定义自定义命令。 创建 `.opencode/commands/test.md`: ```md title=".opencode/commands/test.md" --- description: Run tests with coverage agent: build model: anthropic/claude-3-5-sonnet-20241022 --- Run the full test suite with coverage report and show any failures. Focus on the failing tests and suggest fixes. ``` frontmatter 定义命令属性,内容则成为模板。 通过输入 `/` 后跟命令名称来使用该命令。 ```bash frame="none" "/test" ``` --- ## 配置 你可以通过 OpenCode 配置或在 `commands/` 目录中创建 markdown 文件来添加自定义命令。 --- ### JSON 在 OpenCode [配置](/docs/config)中使用 `command` 选项: ```json title="opencode.jsonc" {4-12} { "$schema": "https://opencode.ai/config.json", "command": { // This becomes the name of the command "test": { // This is the prompt that will be sent to the LLM "template": "Run the full test suite with coverage report and show any failures.\nFocus on the failing tests and suggest fixes.", // This is shown as the description in the TUI "description": "Run tests with coverage", "agent": "build", "model": "anthropic/claude-3-5-sonnet-20241022" } } } ``` 现在你可以在 TUI 中运行这个命令: ```bash frame="none" /test ``` --- ### Markdown 你还可以使用 markdown 文件定义命令。将它们放在: - 全局:`~/.config/opencode/commands/` - 项目级:`.opencode/commands/` ```markdown title="~/.config/opencode/commands/test.md" --- description: Run tests with coverage agent: build model: anthropic/claude-3-5-sonnet-20241022 --- Run the full test suite with coverage report and show any failures. Focus on the failing tests and suggest fixes. ``` markdown 文件名即为命令名。例如,`test.md` 允许你运行: ```bash frame="none" /test ``` --- ## 提示词配置 自定义命令的提示词支持多种特殊占位符和语法。 --- ### 参数 使用 `$ARGUMENTS` 占位符向命令传递参数。 ```md title=".opencode/commands/component.md" --- description: Create a new component --- Create a new React component named $ARGUMENTS with TypeScript support. Include proper typing and basic structure. ``` 带参数运行命令: ```bash frame="none" /component Button ``` `$ARGUMENTS` 将被替换为 `Button`。 你还可以使用位置参数访问各个参数: - `$1` - 第一个参数 - `$2` - 第二个参数 - `$3` - 第三个参数 - 以此类推... 例如: ```md title=".opencode/commands/create-file.md" --- description: Create a new file with content --- Create a file named $1 in the directory $2 with the following content: $3 ``` 运行命令: ```bash frame="none" /create-file config.json src "{ \"key\": \"value\" }" ``` 替换结果为: - `$1` 替换为 `config.json` - `$2` 替换为 `src` - `$3` 替换为 `{ "key": "value" }` --- ### Shell 输出 使用 _!`command`_ 将 [bash 命令](/docs/tui#bash-commands)输出注入到提示词中。 例如,创建一个分析测试覆盖率的自定义命令: ```md title=".opencode/commands/analyze-coverage.md" --- description: Analyze test coverage --- Here are the current test results: !`npm test` Based on these results, suggest improvements to increase coverage. ``` 或者查看最近的更改: ```md title=".opencode/commands/review-changes.md" --- description: Review recent changes --- Recent git commits: !`git log --oneline -10` Review these changes and suggest any improvements. ``` 命令在项目的根目录中运行,其输出会成为提示词的一部分。 --- ### 文件引用 使用 `@` 后跟文件名在命令中引用文件。 ```md title=".opencode/commands/review-component.md" --- description: Review component --- Review the component in @src/components/Button.tsx. Check for performance issues and suggest improvements. ``` 文件内容会自动包含在提示词中。 --- ## 选项 让我们详细了解各配置选项。 --- ### Template `template` 选项定义执行命令时发送给 LLM 的提示词。 ```json title="opencode.json" { "command": { "test": { "template": "Run the full test suite with coverage report and show any failures.\nFocus on the failing tests and suggest fixes." } } } ``` 这是一个**必需的**配置选项。 --- ### Description 使用 `description` 选项提供命令功能的简要描述。 ```json title="opencode.json" { "command": { "test": { "description": "Run tests with coverage" } } } ``` 当你输入命令时,这将在 TUI 中显示为描述。 --- ### Agent 使用 `agent` 配置可选地指定由哪个[代理](/docs/agents)执行此命令。 如果这是一个[子代理](/docs/agents/#subagents),该命令默认会触发子代理调用。 要禁用此行为,请将 `subtask` 设置为 `false`。 ```json title="opencode.json" { "command": { "review": { "agent": "plan" } } } ``` 这是一个**可选的**配置选项。如果未指定,默认使用你当前的代理。 --- ### Subtask 使用 `subtask` 布尔值强制命令触发[子代理](/docs/agents/#subagents)调用。 如果你希望命令不污染主要上下文,这会很有用,它会**强制**代理作为子代理运行, 即使[代理](/docs/agents)配置中的 `mode` 设置为 `primary`。 ```json title="opencode.json" { "command": { "analyze": { "subtask": true } } } ``` 这是一个**可选的**配置选项。 --- ### Model 使用 `model` 配置覆盖此命令的默认模型。 ```json title="opencode.json" { "command": { "analyze": { "model": "anthropic/claude-3-5-sonnet-20241022" } } } ``` 这是一个**可选的**配置选项。 --- ## 内置命令 opencode 包含多个内置命令,如 `/init`、`/undo`、`/redo`、`/share`、`/help`;[了解更多](/docs/tui#commands)。 :::note 自定义命令可以覆盖内置命令。 ::: 如果你定义了同名的自定义命令,它将覆盖内置命令。