工作區
pnpm 內建了對 Monorepo (單一存放庫,又稱為多重套件存放庫、多重專案存放庫或整合型存放庫) 的支援。 您可以建立一個工作區來將多個專案結合在單個存放庫的內部。
工作區的根目錄中必須具有 pnpm-workspace.yaml
檔。 工作區的根目錄中也可能會具有 .npmrc
。
如果您要研究 Monorepo 管理,那麽您還可能想要研究 Bit (英文網頁)。 Bit 實際上使用的是 pnpm,不過它會自動執行許多動作,目前在 pnpm/npm/Yarn 管理的傳統工作區中,這些 動作則需要手動執行。 有一篇 bit install
方面的文章提到了這些:〈用 Bit 輕鬆管理 Monorepo 依賴套件〉(英文網頁)。
工作區通訊協定 (workspace:)
預設情況下,如果可用的套件與宣告範圍相符,pnpm 將會建立工作區中的套件的連結。 例如,若 bar
的相依性中具有 "foo": "1.0.0"
,且 foo@1.0.0
位於工作區,則會在 bar
中建立 foo@1.0.0
的連結。 不過,若 bar
的相依性中具有 "foo": "2.0.0"
,且 foo@2.0.0
不位於工作區,則將會從登錄檔中安裝 foo@2.0.0
。 這個行為會導致一些不確定性。
幸好,pnpm 支援 workspace:
通訊協定。 使用此通訊協定時,pnpm 會拒絕解析除本機工作區套件之外的任何內容。 因此,如果您設定 "foo": "workspace:2.0.0"
,此次會安裝失敗,因為 "foo@2.0.0"
不在工作區中。
當 link-workspace-packages 選項設定為 false
時,這個通訊協定會特別有用。 在這種情況下,若使用 workspace:
通訊協定,則 pnpm 僅會建立工作區中套件的連結。