Yarn與Lerna管理monorepo使用詳解
什么是 Yarn workspace
Yarn workspace 是 Yarn 提供的 monorepo 下,管理依賴的機制。對代碼倉庫下,多個 package 的依賴,進行管理:將共同的依賴,做 hosting(提升)。這樣,可以防止 package 中的包重復(fù)安裝。 workspace 機制,會在根目錄下,統(tǒng)一安裝依賴到 node_module,并生成 yarn.lock。單個 package 下,不需要再生成 yarn.lock。
如何使用 Yarn workspace
1.Yarn 啟用工作區(qū)
yarn config set workspaces-experimental true
命令的含義:添加workspaces-experimental true
到系統(tǒng)全局的.yarnrc
中。
2.修改根目錄的 package.json,添加如下內(nèi)容:
{ "private": true, ... "workspaces": ["packages/*"] }
配置項含義: private - 禁止發(fā)布根目錄內(nèi)容 workspaces - 設(shè)置工作區(qū),聲明 workspace 中 package 的路徑。值是一個字符串?dāng)?shù)組,支持 Glob 通配符。
Lerna 安裝依賴的方式
Lerna 安裝依賴的方式,是使用命令lerna bootstrap
。 該命令的作用,是 cd 到 package 文件夾下的每個子文件夾,運行npm install
或yarn install
,在子文件夾中生成版本lock文件和node_module
,單獨對依賴進行管理。
Yarn workspace 與 Lerna 結(jié)合
結(jié)合的方式
- 配置 lerna.json
{ ... "npmClient": "yarn", "useWorkspaces": true }
- 配置 package.json
{ "private": true, ... "workspaces": ["packages/*"] }
角色的分配
Yarn 負(fù)責(zé)管理依賴,workspace 會自動對 package 的引用 ,設(shè)置軟鏈接(symlink),并且軟鏈接僅在當(dāng)前 workspace 中生效。 Lerna 負(fù)責(zé)版本的發(fā)布工作,對 package 相互之間的依賴,做好版本管理。
好處
減少項目的磁盤占用空間
Yarn 將項目中的共同依賴,提升到根目錄下進行安裝
自動設(shè)置軟鏈接,方便調(diào)試
Yarn 的 workspace 會自動對 package 的引用,設(shè)置 symlink
- 所有 package 使用同一個 yarn.lock,更少造成沖突且易于審查
使用
- 首次安裝依賴
lerna bootstrap
- 安裝
dependencies
依賴 `yarn add -W [pkg] - 安裝
devDependencies
依賴yarn add -D -W [pkg]
-W
的含義: 安裝依賴到 workspace -D的含義: 安裝依賴到devDependencies`
以上就是Yarn與Lerna管理monorepo使用詳解的詳細(xì)內(nèi)容,更多關(guān)于Yarn Lerna管理monorepo的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Vue學(xué)習(xí)筆記進階篇之vue-cli安裝及介紹
這篇文章主要介紹了Vue學(xué)習(xí)筆記進階篇之vue-cli安裝及介紹,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07VUE Error: getaddrinfo ENOTFOUND localhost
這篇文章主要介紹了VUE Error: getaddrinfo ENOTFOUND localhost,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05vue+element實現(xiàn)下拉菜單并帶本地搜索功能示例詳解
這篇文章主要介紹了vue+element實現(xiàn)下拉菜單并帶本地搜索功能,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-09-09sortable+element 實現(xiàn)表格行拖拽的方法示例
這篇文章主要介紹了sortable+element 實現(xiàn)表格行拖拽的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-06-06