摘要:最近發(fā)現(xiàn)公司一個項目的目錄組織挺奇怪的,所有的子項目都放在了目錄里,還有這種騷操作特意查了下資料,發(fā)現(xiàn)是一種比較流行的項目管理模式。
最近發(fā)現(xiàn)公司一個項目的目錄組織挺奇怪的,所有的子項目都放在了packages目錄里,還有這種騷操作?特意查了下資料,發(fā)現(xiàn)是一種比較流行的monorepo項目管理模式。近幾年比較火的React,Vue,Babel都是用的這種模式:
我們平常一般采用的都是multiple repositories的項目管理模式:把一個大項目拆分成若干個小項目,每個小項目都獨立的放在gitlab上。這種模式其實也沒啥不好,但是某些情況下,子項目A依賴子項目B,如果子項目B經(jīng)常改動,那么每次B改動了,都要修改A,這時就非常麻煩。在開發(fā)一個前端框架或者UI庫時,就經(jīng)常會遇到上述情況,這時我們就可以考慮下monorepo。
monorepo說到底也只是一個理念,那么怎么才能實現(xiàn)這種代碼組織呢?
lerna
yarn中的Workspace
本文主要介紹下lerna的使用
源碼參考
lerna全局安裝lerna
npm i lerna -g
lerna是基于git的,在github上新建一個項目learn-lerna
git clone git@github.com:deepred5/learn-lerna.git cd learn-lerna
初始化項目:
lerna init
lerna會自動創(chuàng)建一個packages目錄夾,我們以后的項目都新建在這里面。同時還會在根目錄新建一個lerna.json配置文件
{ "packages": [ "packages/*" ], "version": "0.0.0" // 共用的版本,由lerna管理 }創(chuàng)建package
我們創(chuàng)建兩個package:
cd packages mkdir prpr-lerna-core cd prpr-lerna-core npm init -y
cd packages mkdir prpr-lerna-popular cd prpr-lerna-popular npm init -y
注意:這兩個package我們最后都是要發(fā)布到npm上的,所以名字請取特殊些,不能被人用過
添加依賴prpr-lerna-popular依賴prpr-lerna-core,這時有兩種方法添加依賴:
第一種方法是修改prpr-lerna-popular/package.json,添加
{ "dependencies": { "prpr-lerna-core": "^1.0.0" } }
然后運行lerna bootstrap
第二種方法是直接使用命令add
lerna add prpr-lerna-core --scope=prpr-lerna-popular
運行之后,我們發(fā)現(xiàn)prpr-lerna-popular生成了node_modules,而node_modules里生成了指向prpr-lerna-core的軟鏈,類似npm link的效果:
新建prpr-lerna-core/index.js
const API = "https://yande.re/post/popular_recent.json"; module.exports = { API }
prpr-lerna-popular除了依賴prpr-lerna-core,還可以依賴其他開源的庫,比如我們使用axios
lerna add axios --scope=prpr-lerna-popular
新建prpr-lerna-popular/index.js
const { API } = require("prpr-lerna-core"); const axios = require("axios"); const getPopularImg = () => axios.get(API) module.exports = getPopularImg; // 測試代碼,發(fā)布時刪除 getPopularImg().then((res) => console.log(res.data.length));
測試一下:
node packages/prpr-lerna-popular/index.js
正常情況下可以輸出結(jié)果
首先把所有的代碼提交
cd learn-lerna git add . git commit -m "test publish"
注冊一個npmjs賬戶
npm login
登入你的賬戶,如果本地npm是淘寶鏡像,一定要換回https://registry.npmjs.org/地址!!!
lerna publish
運行publish,選擇發(fā)布的版本號
lerna可以幫我們管理版本號,非常方便!
常用命令lerna init #初始化 lerna bootstrap #下載依賴包或者生成本地軟連接 lerna add axios #所有包都添加axios lerna add prpr-lerna-core --scope=prpr-lerna-popular #給包prpr-lerna-popularx添加prpr-lerna-core依賴 lerna list lerna clean其他事項
lerna默認使用的是集中版本,所有的package共用一個version。如果希望不同的package擁有自己的版本,可以使用Independent模式
發(fā)布package的名字如果是以@開頭的,例如@deepred/core,npm默認以為是私人發(fā)布,需要使用npm publish --access public發(fā)布。但是lerna publish不支持該參數(shù),解決方法參考: issues
參考淺談monorepo
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/105444.html
摘要:如何像那樣進行多包管理呢項目的里面存放了旗下的所有包,比如。如果你不想這么麻煩,那么有一個辦法就是,不用,也就是你的包名不加前綴,這樣你的包就默認是公共的包了,完全可以不用先去提交一次公共版本,才能使用來管理你的包,簡單多了。 溫馨提示:請直接看最后面的正確操作,如果不懂,再回顧全文。 如何像 babel 那樣進行多包管理呢? babel 項目的 packages 里面存放了 babe...
摘要:目前最常見的解決方案是和的特性。具體的使用方法移步官網(wǎng)而使用作為包管理器的同學(xué),可以在中以字段聲明,就會以的方式管理。這樣的話,無論你的包管理器是還是,都能發(fā)揮的優(yōu)勢要是包管理是,就會把依賴安裝交給處理。 最近我接手了一個項目,代碼量比較大、有點復(fù)雜。倉庫 clone 下來代碼有 50+ MB,npm install 安裝完體積飚到了近 2GB …… 熟悉了一下,這個項目比較復(fù)雜,采用...
摘要:從到完美,寫一個庫庫前端組件庫之前講了很多關(guān)于項目工程化前端架構(gòu)前端構(gòu)建等方面的技術(shù),這次說說怎么寫一個完美的第三方庫。使用導(dǎo)出模塊,就可以在使用這個庫的項目中構(gòu)建時使用功能。 從 1 到完美,寫一個 js 庫、node 庫、前端組件庫 之前講了很多關(guān)于項目工程化、前端架構(gòu)、前端構(gòu)建等方面的技術(shù),這次說說怎么寫一個完美的第三方庫。 1. 選擇合適的規(guī)范來寫代碼 js 模塊化的發(fā)展大致有...
摘要:從到完美,寫一個庫庫前端組件庫之前講了很多關(guān)于項目工程化前端架構(gòu)前端構(gòu)建等方面的技術(shù),這次說說怎么寫一個完美的第三方庫。使用導(dǎo)出模塊,就可以在使用這個庫的項目中構(gòu)建時使用功能。 從 1 到完美,寫一個 js 庫、node 庫、前端組件庫 之前講了很多關(guān)于項目工程化、前端架構(gòu)、前端構(gòu)建等方面的技術(shù),這次說說怎么寫一個完美的第三方庫。 1. 選擇合適的規(guī)范來寫代碼 js 模塊化的發(fā)展大致有...
我們先說下 Yarn workspace 首先Yarn workspace 是 Yarn 提供的 monorepo 下,管理依賴的機制。這就說主要對代碼倉庫下,多個 package 的依賴,進行管理:將共同的依賴,做 hosting(提升)。前述這樣就可以有效的防止 package 中的包重復(fù)安裝。 workspace 機制,會在根目錄下,統(tǒng)一安裝依賴到 node_module,并生成...
閱讀 2424·2021-11-11 11:01
閱讀 3300·2021-10-11 10:57
閱讀 2659·2021-09-30 09:46
閱讀 3500·2021-07-26 23:38
閱讀 1575·2019-08-29 12:22
閱讀 658·2019-08-29 11:28
閱讀 2361·2019-08-26 14:04
閱讀 3061·2019-08-23 18:34