|
| 1 | +--- |
| 2 | +title: 升級 Astro |
| 3 | +description: 了解如何升級 Astro |
| 4 | +i18nReady: true |
| 5 | +--- |
| 6 | +import PackageManagerTabs from '~/components/tabs/PackageManagerTabs.astro'; |
| 7 | +import Version from '~/components/Version.astro'; |
| 8 | + |
| 9 | +本指南涵蓋如何更新你的 Astro 版本及相關相依套件、如何了解各版本之間的變更,以及如何理解 Astro 的版本編號系統和對應的文件更新。 |
| 10 | + |
| 11 | +## 有什麼變更? |
| 12 | + |
| 13 | +Astro 的最新版本是 <Version pkgName="astro" />。 |
| 14 | + |
| 15 | +你可以在 [Astro 的變更日誌](https://github.com/withastro/astro/blob/main/packages/astro/CHANGELOG.md)中找到所有變更的完整清單,以及在我們的[升級指南](#升級指南)中找到每個新[主要版本](#主要變更)的重要升級說明。 |
| 16 | + |
| 17 | +## 升級至最新版本 |
| 18 | + |
| 19 | +使用你的套件管理工具,透過一個指令將專案中的 Astro 和所有官方整合更新到最新版本: |
| 20 | + |
| 21 | +<PackageManagerTabs> |
| 22 | + <Fragment slot="npm"> |
| 23 | + ```shell |
| 24 | + # 一起升級 Astro 和官方整合 |
| 25 | + npx @astrojs/upgrade |
| 26 | + ``` |
| 27 | + </Fragment> |
| 28 | + <Fragment slot="pnpm"> |
| 29 | + ```shell |
| 30 | + # 一起升級 Astro 和官方整合 |
| 31 | + pnpm dlx @astrojs/upgrade |
| 32 | + ``` |
| 33 | + </Fragment> |
| 34 | + <Fragment slot="yarn"> |
| 35 | + ```shell |
| 36 | + # 一起升級 Astro 和官方整合 |
| 37 | + yarn dlx @astrojs/upgrade |
| 38 | + ``` |
| 39 | + </Fragment> |
| 40 | +</PackageManagerTabs> |
| 41 | + |
| 42 | +### 手動升級 |
| 43 | + |
| 44 | +若要手動將 Astro 和整合更新至最新版本,請使用你的套件管理工具對應的指令。 |
| 45 | + |
| 46 | +<PackageManagerTabs> |
| 47 | + <Fragment slot="npm"> |
| 48 | + ```shell |
| 49 | + # 範例:升級 Astro 以及 React 和 Partytown 整合 |
| 50 | + npm install astro@latest @astrojs/react@latest @astrojs/partytown@latest |
| 51 | + ``` |
| 52 | + </Fragment> |
| 53 | + <Fragment slot="pnpm"> |
| 54 | + ```shell |
| 55 | + # 範例:升級 Astro 以及 React 和 Partytown 整合 |
| 56 | + pnpm add astro@latest @astrojs/react@latest @astrojs/partytown@latest |
| 57 | + ``` |
| 58 | + </Fragment> |
| 59 | + <Fragment slot="yarn"> |
| 60 | + ```shell |
| 61 | + # 範例:升級 Astro 以及 React 和 Partytown 整合 |
| 62 | + yarn add astro@latest @astrojs/react@latest @astrojs/partytown@latest |
| 63 | + ``` |
| 64 | + </Fragment> |
| 65 | +</PackageManagerTabs> |
| 66 | + |
| 67 | +### 安裝特定版本號 |
| 68 | + |
| 69 | +若要安裝特定[版本的 Astro](https://www.npmjs.com/package/astro?activeTab=versions) 或整合,請使用你的套件管理工具對應的指令。 |
| 70 | + |
| 71 | +<PackageManagerTabs> |
| 72 | + <Fragment slot="npm"> |
| 73 | + ```shell |
| 74 | + npm install astro@4.5.3 @astrojs/react@3.0.10 |
| 75 | + ``` |
| 76 | + </Fragment> |
| 77 | + <Fragment slot="pnpm"> |
| 78 | + ```shell |
| 79 | + pnpm add astro@4.5.3 @astrojs/react@3.0.10 |
| 80 | + ``` |
| 81 | + </Fragment> |
| 82 | + <Fragment slot="yarn"> |
| 83 | + ```shell |
| 84 | + yarn add astro@4.5.3 @astrojs/react@3.0.10 |
| 85 | + ``` |
| 86 | + </Fragment> |
| 87 | +</PackageManagerTabs> |
| 88 | + |
| 89 | +## 文件更新 |
| 90 | + |
| 91 | +本文件會在每次[次要版本](#次要變更)和[主要版本](#主要變更)發布時更新。當新增功能或現有用法有變更時,文件會更新以反映 **Astro 的當前行為**。如果你的專案尚未更新,你可能會注意到某些行為與最新文件不一致。 |
| 92 | + |
| 93 | +新功能會在文件中標註其加入的特定版本號。這表示如果你尚未更新至 Astro 的最新版本,部分已記載的功能可能無法使用。請務必確認 `Added in:` 的版本號,並在嘗試使用新功能前確保你的專案已更新! |
| 94 | + |
| 95 | +如果你尚未升級至 Astro 的最新主要版本,你可能會遇到 Astro 文件與專案行為之間的顯著差異。我們強烈建議你盡快升級至當前的主要版本。舊版的程式碼和文件均不再受到支援。 |
| 96 | + |
| 97 | +### 升級指南 |
| 98 | + |
| 99 | +在每次[主要版本發布](#主要變更)後,你會找到一份**升級指南**,其中包含重要變更的資訊和升級專案程式碼的說明。 |
| 100 | + |
| 101 | +Astro 的主要文件頁面始終**精確對應最新發布的 Astro 版本**。它們不會描述或比較舊版本的運作方式,也不會特別標註更新或變更的行為。 |
| 102 | + |
| 103 | +請參閱以下升級指南,了解新舊版本之間的變更說明。升級指南包含所有可能需要你修改程式碼的內容:重大變更、棄用功能、功能移除和替代方案,以及更新的使用指南。Astro 的每項變更都包含一個「我該怎麼做?」段落,幫助你成功更新專案程式碼。 |
| 104 | + |
| 105 | +- [升級至 v6](/zh-tw/guides/upgrade-to/v6/) |
| 106 | +- [升級至 v5](/zh-tw/guides/upgrade-to/v5/) |
| 107 | +- [升級至 v4](/zh-tw/guides/upgrade-to/v4/) |
| 108 | +- [升級至 v3](/zh-tw/guides/upgrade-to/v3/) |
| 109 | +- [升級至 v2](/zh-tw/guides/upgrade-to/v2/) |
| 110 | +- [升級至 v1](/zh-tw/guides/upgrade-to/v1/) |
| 111 | + |
| 112 | +### 舊版文件(不再維護) |
| 113 | + |
| 114 | +舊版 Astro 的文件不再維護,但仍以靜態快照的形式提供。如果你無法升級專案但仍希望查閱指南和參考資料,可以使用這些版本的文件: |
| 115 | + |
| 116 | +- [不再維護的 v5.18.0 快照](https://v5.docs.astro.build/en/getting-started/) |
| 117 | +- [不再維護的 v4.16.17 快照](https://v4.docs.astro.build/en/getting-started/) |
| 118 | +- [不再維護的 v3.6.3 快照](https://web.archive.org/web/20231203051122/https://docs.astro.build/en/getting-started/) |
| 119 | +- [不再維護的 v2.10.15 快照](https://web.archive.org/web/20230822134745/https://docs.astro.build/en/getting-started) |
| 120 | + |
| 121 | +## 語意化版本 |
| 122 | + |
| 123 | +Astro 盡可能遵循[語意化版本](https://semver.org/),這是一組開發者用來決定如何為版本分配版本號的規則。語意化版本遵循可預測的模式,讓使用者了解從一個版本到下一個版本可以預期的變更類型。 |
| 124 | + |
| 125 | +語意化版本規定軟體版本號採用 `X.Y.Z` 的格式。這些數值分別代表**主要版本 (X)**、**次要版本 (Y)** 和**修補版本 (Z)** 更新。 |
| 126 | + |
| 127 | +### 修補變更 |
| 128 | + |
| 129 | +修補變更是影響最小的變更。它們不會改變你使用 Astro 的方式,更新時也不需要修改你的程式碼。 |
| 130 | + |
| 131 | +當 Astro 發布「修補」版本時,最後一個數字會增加。(例如 `astro@4.3.14` -> `astro@4.3.15`) |
| 132 | + |
| 133 | +修補版本的發布原因包括: |
| 134 | + |
| 135 | +- 不影響 Astro 功能的內部變更: |
| 136 | + - 重構 |
| 137 | + - 效能改善 |
| 138 | + - 測試覆蓋率的增加或變更 |
| 139 | + - 使行為符合已記載的文件和預期行為 |
| 140 | +- 日誌和錯誤訊息的改善。 |
| 141 | +- 失敗發布後的重新發布。 |
| 142 | + |
| 143 | +修補變更也包含**大多數的錯誤修正**,即使在使用者利用了現有的非預期或不理想行為的情況下也是如此。 |
| 144 | + |
| 145 | +### 次要變更 |
| 146 | + |
| 147 | +次要版本主要引入你可能想嘗試的新功能和改善,但不需要修改你的程式碼。某些現有功能也可能在次要版本中被**棄用**(標記為將在未來版本中刪除,但仍繼續運作),讓你有時間為其最終移除做好準備。 |
| 148 | + |
| 149 | +次要版本包含的變更如: |
| 150 | + |
| 151 | +- **棄用**現有功能 / 選項,並警告它們將在即將到來的主要版本中被移除。 |
| 152 | +- 引入新功能。 |
| 153 | +- 在整合鉤子中引入新選項。 |
| 154 | +- 在 `astro/app` 中引入新功能,主要用於建立新的配接器。 |
| 155 | + |
| 156 | +次要版本也可能同時包含較小的修補變更。 |
| 157 | + |
| 158 | +### 主要變更 |
| 159 | + |
| 160 | +主要版本將包含至少部分現有程式碼的重大變更。這些重大變更總是記錄在 Astro 的[「升級至 vX」指南](#升級指南)中。 |
| 161 | + |
| 162 | +主要版本允許 Astro 對內部邏輯以及預期行為和用法進行重大更改。文件將僅更新以反映最新版本,而**靜態的、不再維護的舊版文件快照**則作為尚未升級的舊專案的歷史紀錄。 |
| 163 | + |
| 164 | +主要版本包含的變更如: |
| 165 | + |
| 166 | +- 移除先前棄用的功能。 |
| 167 | +- 變更現有功能。 |
| 168 | +- 變更整合鉤子中的現有選項。 |
| 169 | +- 變更 `astro/app` 中的現有選項和功能,主要用於建立新的配接器。 |
| 170 | + |
| 171 | +主要版本也可能包含一些通常會在次要或修補版本中單獨發布的非重大變更和改善。 |
| 172 | + |
| 173 | +### 例外情況 |
| 174 | + |
| 175 | +- **實驗性功能**。在不遵循語意化版本的情況下發布 Astro 版本,讓 Astro 開發者在開發實驗性功能期間擁有最大的靈活性,甚至可以徹底改變方向。因此,這些功能的行為可能會在次要和修補變更中產生重大改變。 |
| 176 | + |
| 177 | + 這些功能通常伴隨著一個進行中的、公開的 [Request for Consideration (RFC) 第三階段](https://github.com/withastro/roadmap#stage-3-rfc--development)。預期測試版使用者會持續關注更新,並在討論中提供早期回饋,以協助引導這些功能的開發。 |
| 178 | + |
| 179 | + 一旦這些功能結束實驗期,它們將遵循正常的語意化版本契約。 |
| 180 | + |
| 181 | +- **文件改善**(例如參考資料和錯誤訊息)。這些是從 `docs` 儲存庫的原始碼建置的。這讓 Astro 可以在文件來源內容儲存在主要 `astro` 儲存庫中的情況下,快速更新文件修正和改善。 |
| 182 | + |
| 183 | +### Node.js 支援和升級政策 |
| 184 | + |
| 185 | +#### 支援 |
| 186 | + |
| 187 | +- Astro 支援 [**最新的 _Maintenance_ LTS** 版本的 Node.js](https://nodejs.org/en/about/previous-releases#release-schedule)。 |
| 188 | +- Astro 支援[**當前的 _Active_ LTS** 版本的 Node.js](https://nodejs.org/en/about/previous-releases#release-schedule)。 |
| 189 | +- Astro 可以支援奇數版本的 Node.js。 |
| 190 | + |
| 191 | +#### 升級 |
| 192 | + |
| 193 | +以下規則定義了 Astro 何時可以棄用、停止支援或新增支援 Node.js 版本: |
| 194 | + |
| 195 | +- 當下一個偶數版本的 Node.js 發布時,奇數版本的 Node.js 可以被棄用和 / 或停止支援。此變更可以在 Astro 的**次要**版本中進行,但須經過 Astro 核心團隊決定的合理延長支援期。 |
| 196 | +- 升級最低 **_Maintenance_ LTS** 版本(在同一主要版本範圍內,例如從 `22.14.*` 到 `22.20.*`)可以在 Astro 的**次要**版本中進行。 |
| 197 | + - 安全性例外:如果披露並修正了一個**影響 Astro** 的 Node.js 安全漏洞,核心團隊可以在**修補**版本中提升最低 **_Maintenance_ LTS** 版本。 |
| 198 | +- 升級 Node.js 的次要或主要版本(**非** Maintenance LTS)僅在 Astro 的主要版本中進行。 |
| 199 | + - 安全性例外:如果披露並修正了一個**影響 Astro** 的 Node.js 安全漏洞,核心團隊可以在**次要**版本中提升最低版本。 |
| 200 | + |
| 201 | +### 延長維護 |
| 202 | + |
| 203 | +核心團隊將**僅針對安全修正**為前一個主要版本提供延長維護。這表示如果當前主要版本是 `v4.*`,核心團隊會將安全修正向後移植並發布新的 `v3.*` 版本。 |
0 commit comments