docs: improve zh-cn and zh-tw documentation translations (#13942)

This commit is contained in:
chenmi
2026-02-17 20:06:39 +08:00
committed by GitHub
parent 8d0a303af4
commit 4fd3141ab5
68 changed files with 4624 additions and 4518 deletions

View File

@@ -1,63 +1,64 @@
---
title: 格式化程式
description: opencode 使用特定語言的格式化程式
title: 格式化
description: OpenCode 使用特定語言的格式化
---
使用特定於語言的格式化程式編寫或編輯檔案後opencode 會自動格式化檔案。這確保生成的程式碼遵循專案的程式碼風格。
OpenCode 會在檔案寫入或編輯後,自動使用特定語言的格式化器對其進行格式化。這確保生成的程式碼遵循專案的程式碼風格。
---
## 內建
## 內建格式化器
opencode 附帶了多適用於流語言和框架的內建格式化程式。下面是格式化程式、支援的檔案副檔名以及所需的指令或設定選項的列表
OpenCode 內建了多適用於流語言和框架的格式化器。下表列出了各格式化、支援的副檔名以及所需的指令或設定選項。
| 格式化程式 | 副檔名 | 要求 |
| -------------------- | ------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------- |
| gofmt | .go | `gofmt` 指令可用 |
| mix | .ex, .exs, .eex, .heex, .leex, .neex, .sface | `mix` 指令可用 |
| prettier | .js, .jsx, .ts, .tsx, .html, .css, .md, .json, .yaml, 和 [更多](https://prettier.io/docs/en/index.html) | `prettier` 中有 `package.json` 相依套件 |
| biome | .js, .jsx, .ts, .tsx, .html, .css, .md, .json, .yaml, 和 [更多](https://biomejs.dev/) | `biome.json(c)` 設定檔 |
| zig | .zig, .zon | `zig` 指令可用 |
| clang-format | .c, .cpp, .h, .hpp, .ino, 和 [更多](https://clang.llvm.org/docs/ClangFormat.html) | `.clang-format` 設定檔 |
| ktlint | .kt, .kts | `ktlint` 指令可用 |
| ruff | .py, .pyi | `ruff` 指令可用並設定完成 |
| rustfmt | .rs | `rustfmt` 指令可用 |
| cargofmt | .rs | `cargo fmt` 指令可用 |
| uv | .py, .pyi | `uv` 指令可用 |
| rubocop | .rb, .rake, .gemspec, .ru | `rubocop` 指令可用 |
| standardrb | .rb, .rake, .gemspec, .ru | `standardrb` 指令可用 |
| htmlbeautifier | .erb, .html.erb | `htmlbeautifier` 指令可用 |
| air | .R | `air` 指令可用 |
| dart | .dart | `dart` 指令可用 |
| dfmt | .d | `dfmt` 指令可用 |
| ocamlformat | .ml, .mli | `ocamlformat` 指令可用,且存在 `.ocamlformat` 設定檔 |
| terraform | .tf, .tfvars | `terraform` 指令可用 |
| gleam | .gleam | `gleam` 指令可用 |
| nixfmt | .nix | `nixfmt` 指令可用 |
| shfmt | .sh, .bash | `shfmt` 指令可用 |
| pint | .php | `laravel/pint` 中有 `composer.json` 相依套件 |
| oxfmt (Experimental) | .js, .jsx, .ts, .tsx | `oxfmt` 中有 `package.json` 相依套件且啟用[實驗環境變數旗標](/docs/cli/#experimental) |
| ormolu | .hs | `ormolu` 指令可用 |
| 格式化 | 副檔名 | 要求 |
| -------------------- | ----------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------- |
| air | .R | `air` 指令可用 |
| biome | .js, .jsx, .ts, .tsx, .html, .css, .md, .json, .yaml 及[更多](https://biomejs.dev/) | `biome.json(c)` 設定檔 |
| cargofmt | .rs | `cargo fmt` 指令可用 |
| clang-format | .c, .cpp, .h, .hpp, .ino 及[更多](https://clang.llvm.org/docs/ClangFormat.html) | `.clang-format` 設定檔 |
| cljfmt | .clj, .cljs, .cljc, .edn | `cljfmt` 指令可用 |
| dart | .dart | `dart` 指令可用 |
| dfmt | .d | `dfmt` 指令可用 |
| gleam | .gleam | `gleam` 指令可用 |
| gofmt | .go | `gofmt` 指令可用 |
| htmlbeautifier | .erb, .html.erb | `htmlbeautifier` 指令可用 |
| ktlint | .kt, .kts | `ktlint` 指令可用 |
| mix | .ex, .exs, .eex, .heex, .leex, .neex, .sface | `mix` 指令可用 |
| nixfmt | .nix | `nixfmt` 指令可用 |
| ocamlformat | .ml, .mli | `ocamlformat` 指令可用且存在 `.ocamlformat` 設定檔 |
| ormolu | .hs | `ormolu` 指令可用 |
| oxfmt (Experimental) | .js, .jsx, .ts, .tsx | `package.json` 中有 `oxfmt` 相依套件,且設定了[實驗性環境變數旗標](/docs/cli/#experimental) |
| pint | .php | `composer.json` 中有 `laravel/pint` 相依套件 |
| prettier | .js, .jsx, .ts, .tsx, .html, .css, .md, .json, .yaml 及[更多](https://prettier.io/docs/en/index.html) | `package.json` 中有 `prettier` 相依套件 |
| rubocop | .rb, .rake, .gemspec, .ru | `rubocop` 指令可用 |
| ruff | .py, .pyi | `ruff` 指令可用且有相應設定 |
| rustfmt | .rs | `rustfmt` 指令可用 |
| shfmt | .sh, .bash | `shfmt` 指令可用 |
| standardrb | .rb, .rake, .gemspec, .ru | `standardrb` 指令可用 |
| terraform | .tf, .tfvars | `terraform` 指令可用 |
| uv | .py, .pyi | `uv` 指令可用 |
| zig | .zig, .zon | `zig` 指令可用 |
因此,如果您的專案 `package.json` 中 `prettier`opencode 自動使用它。
因此,如果您的專案 `package.json` 中包含 `prettier`OpenCode 自動使用它進行格式化
---
## 它是如何運作的
## 工作原理
opencode 寫入或編輯檔案時,它:
OpenCode 寫入或編輯檔案時,它
1. 根據所有啟用的格式化程式檢查檔案副檔名。
2. 對檔案執行適當的格式化程式指令。
3. 自動套用格式變更。
1. 根據所有啟用的格式化器檢查副檔名。
2. 對檔案執行相應的格式化指令。
3. 自動套用格式變更。
過程在背景進行,確保無需任何手動步驟即可維護您的程式碼樣式
整個過程在背景完成,無需任何手動操作即可保持程式碼風格的一致性
---
## 設定
您可以透過 opencode 設定中的 `formatter` 部分自定義格式化程式
您可以透過 OpenCode 設定中的 `formatter` 部分自格式化
```json title="opencode.json"
{
@@ -66,22 +67,22 @@ opencode 附帶了多個適用於流行語言和框架的內建格式化程式
}
```
每個格式化程式設定支援以下內容
每個格式化器的設定支援以下屬性
| 屬性 | 類型 | 描述 |
| ------------- | ------ | ---------------------------------- |
| `disabled` | 布林值 | 將其設定為 `true` 以禁用格式化程式 |
| `command` | 字串[] | 格式化執行的指令 |
| `environment` | 物件 | 執行格式化程式時要設定的環境變數 |
| `extensions` | 字串[] | 格式化程式應處理的檔案副檔名 |
| 屬性 | 型別 | 說明 |
| ------------- | -------- | ---------------------------- |
| `disabled` | boolean | 設為 `true` 可停用該格式化 |
| `command` | string[] | 執行格式化的指令 |
| `environment` | object | 執行格式化器時設定的環境變數 |
| `extensions` | string[] | 格式化處理的副檔名 |
讓我們看一些例
下面來看一些例。
---
### 用格式化程式
### 用格式化
要全域用**所有**格式化程式,請將 `formatter` 設為 `false`
要全域用**所有**格式化器,將 `formatter` 設為 `false`
```json title="opencode.json" {3}
{
@@ -90,7 +91,7 @@ opencode 附帶了多個適用於流行語言和框架的內建格式化程式
}
```
用**特定**格式化程式,請將 `disabled` 設為 `true`
用**特定**格式化器,將 `disabled` 設為 `true`
```json title="opencode.json" {5}
{
@@ -105,9 +106,9 @@ opencode 附帶了多個適用於流行語言和框架的內建格式化程式
---
### 自定義格式化程式
### 自格式化
您可以覆寫內建格式化程式或透過指定指令、環境變數和檔案副檔名新增新格式化程式
您可以透過指定指令、環境變數和副檔名來覆寫內建格式化器或新增新格式化
```json title="opencode.json" {4-14}
{
@@ -128,4 +129,4 @@ opencode 附帶了多個適用於流行語言和框架的內建格式化程式
}
```
指令中的 **`$FILE` 預留位置** 將替換為正在格式化檔案的路徑。
指令中的 **`$FILE` 佔位符**會被替換為格式化檔案的路徑。