国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

徹底搞懂 npm、yarn 與 pnpm 依賴管理邏輯

開發(fā) 前端
我們?cè)陧?xiàng)目開發(fā)的過(guò)程中會(huì)引用到各種不同的庫(kù),各種庫(kù)又依賴了其他不同的庫(kù),這些依賴應(yīng)該如何進(jìn)行管理,今天這篇文章主要聊的就是這個(gè)事情。


npm2的依賴管理

npm2 安裝依賴的時(shí)候比較簡(jiǎn)單直接,直接按照包依賴的樹形結(jié)構(gòu)下載填充本地目錄結(jié)構(gòu)。

比如在項(xiàng)目中A和 C 都依賴 B,無(wú)論被依賴的 B 是否是同一個(gè)版本,都會(huì)直接無(wú)腦的生成對(duì)應(yīng)的樹結(jié)構(gòu),比如我們現(xiàn)在有下面的依賴:

  • A@2.0.0:BaseA@1.0.0 BaseB@2.0.0
  • B@3.0.0:BaseA@1.0.0 BaseB@2.0.1

那么npm i之后node_modules里面生成的內(nèi)容將是下面這樣的

這樣的結(jié)構(gòu)非常直觀,但是有一個(gè)問(wèn)題就是,如果項(xiàng)目的依賴過(guò)多的話,可能導(dǎo)致下面這些問(wèn)題:

  1. 生成的依賴嵌套非常深
  2. 相同版本的依賴大量冗余

npm3/yarn的依賴管理

npm3對(duì)于npm2的情況進(jìn)行了優(yōu)化,那么如何進(jìn)行優(yōu)化呢?其實(shí)我們最直觀的思路就是將樹打平,將依賴扁平化,不就能解決嵌套過(guò)深和依賴冗余的問(wèn)題。所以,在上面的例子中,如果我們用npm3來(lái)進(jìn)行install,最后生成的node_modules會(huì)是這樣的結(jié)構(gòu):

這樣看起來(lái)是不是就好多了,但是此時(shí)會(huì)有什么問(wèn)題呢?我們實(shí)操一下試試看。在項(xiàng)目中安裝A和B

可以看到我們項(xiàng)目本身的依賴文件里面只有a_klx和b_klx,但是執(zhí)行完npm i命令后卻發(fā)現(xiàn)多了幾個(gè)我們沒(méi)有引入的包a_base_klx和b_base_klx。

其實(shí)這是由a_klx和b_klx本身自己引入的npm包,但是卻出現(xiàn)在了我們的node_modules下。那么如果我們直接使用這兩個(gè)包會(huì)有什么反應(yīng)呢?

可以看到,我們是可以正常使用這兩個(gè)我們并未聲明在依賴中的npm包的,因?yàn)檫@兩個(gè)包存在于我們項(xiàng)目的node_modules下,根據(jù)npm包的查找規(guī)則,我們是可以找到這兩個(gè)包的。所以這種依賴關(guān)系就導(dǎo)致了下面兩個(gè)問(wèn)題:

  1. 我們項(xiàng)目本身的node_modules結(jié)構(gòu)不夠直觀
  2. 依賴不安全,我們可以使用依賴文件中并沒(méi)有聲明的npm包

其實(shí)第一點(diǎn)的問(wèn)題并不是很大,主要是第二點(diǎn)可能會(huì)導(dǎo)致一些奇怪的問(wèn)題。以我們之前的例子來(lái)說(shuō),我們可以直接在項(xiàng)目里面直接使用a_base_klx,因?yàn)閚ode_modules里面這兩個(gè)包實(shí)際上是存在的,但是他們又不是永遠(yuǎn)存在的。

萬(wàn)一有一天,a_klx和b_klx里都去除了這兩個(gè)基礎(chǔ)包的引用,node_modules里面將不再存在a_base_klx和b_base_klx,那么我們的代碼就會(huì)出現(xiàn)問(wèn)題...也就是:

我的代碼啥也沒(méi)動(dòng),放了一個(gè)晚上就壞了!

同時(shí),我們對(duì)于這種處理方式其實(shí)很容易有一個(gè)疑問(wèn),如果我同時(shí)引用了同一個(gè)包的多個(gè)不同版本,會(huì)幫我把哪個(gè)包提出來(lái),同時(shí)我每次npm i之后提出來(lái)的包版本都是一樣的嗎?會(huì)不會(huì)存在這次是2.0.0版本下次是2.0.1版本的情況,比如我們下面這種情況:

  •  A@1.0.0:BaseA@1.0.0 BaseB@2.0.0
  • B@1.0.0:BaseA@1.0.0 BaseB@2.0.1
  • D@1.0.0:BaseA@1.0.0 BaseB@2.0.1

生成的依賴是下面這樣的:

還是下面這樣的:

其實(shí)看起來(lái)后面這個(gè)更合理,因?yàn)橛袃蓚€(gè)包用到了2.0.1版本,將它提出來(lái)更好,我們實(shí)際操作一下試試:

被提到最外層的包是2.0.0版本的,然后b_klx和d_klx的node_modules下面各自有一個(gè) b_base_klx@2.0.1

這一塊的內(nèi)容自己查了一下,大部分說(shuō)法是會(huì)根據(jù)package.json里面的順序決定誰(shuí)會(huì)被提出來(lái),放在前面的包依賴的內(nèi)容會(huì)被先提出來(lái)。

不過(guò)自己實(shí)操了一下發(fā)現(xiàn)并不是這樣,即使我把b_klx或者d_klx移到最前面,被提出來(lái)的包依然是a_klx依賴的2.0.0版本,隨后自己翻了一下npm的源碼,發(fā)現(xiàn)內(nèi)部其實(shí)會(huì)對(duì)拿到的依賴列表進(jìn)行一些處理

最終會(huì)通過(guò)localeCompare方法對(duì)依賴進(jìn)行一次排序,所以字典序在前面的npm包的底層依賴會(huì)被優(yōu)先提出來(lái),對(duì)于我們的例子來(lái)說(shuō)就是a_klx所依賴的b_base_klx@2.0.0會(huì)被優(yōu)先提出來(lái)。

pnpm的依賴管理

pnpm為了解決上述這些問(wèn)題,采用了一種不同于npm/yarn的依賴管理方式。

如果我們用pnpm再來(lái)安裝一遍上面的依賴,會(huì)發(fā)現(xiàn)項(xiàng)目的node_modules文件夾只有當(dāng)前package.json中所聲明的各個(gè)依賴(的軟連接),而真正的模塊文件,存在于node_modules/.pnpm,由模塊名@版本號(hào)形式的文件夾扁平化存儲(chǔ)(解決依賴重復(fù)安裝)。

同時(shí)這樣設(shè)計(jì),也很好的避免了之前可以訪問(wèn)非法npm包的問(wèn)題,因?yàn)楫?dāng)前項(xiàng)目的node_modules只有我們聲明過(guò)的依賴,這也讓node_modules里面的文件看起來(lái)非常的直觀。

同時(shí),node_modules/.pnpm中存儲(chǔ)的文件其實(shí)是pnpm實(shí)際緩存文件的「硬鏈接」,從而避免了多個(gè)項(xiàng)目帶來(lái)多份相同文件引起的空間浪費(fèi)問(wèn)題。

但是說(shuō)到硬鏈接,又有一個(gè)問(wèn)題,這相當(dāng)于所有項(xiàng)目都依賴了同一個(gè)文件,那么在一個(gè)項(xiàng)目中修改了某個(gè)npm包的文件,就會(huì)影響到其他項(xiàng)目,這對(duì)于postinstall是很不友好的。

隨后繼續(xù)實(shí)操了一下,確實(shí)在不同項(xiàng)目中修改了某個(gè)npm包后會(huì)影響到其他項(xiàng)目。同時(shí)自己平時(shí)有時(shí)候也會(huì)直接在node_modules里面調(diào)試一些東西..感覺這種處理方式對(duì)于這種操作來(lái)說(shuō)也不是很友好。

但是從pnpm的官網(wǎng)來(lái)看,其實(shí)它默認(rèn)會(huì)使用copy-on-write 的方式來(lái)進(jìn)行處理,也就是如果你嘗試對(duì)內(nèi)容進(jìn)行修改的話,會(huì)復(fù)制一份文件而不會(huì)影響到源文件。

然后它不生效的原因似乎是因?yàn)閘ibuv的bug:https://github.com/pnpm/pnpm/issues/2761,所以在copy-on-write不生效的情況下被回退到了hardlink  的方式去處理。

責(zé)任編輯:龐桂玉 來(lái)源: 前端大全
相關(guān)推薦

2021-11-29 12:11:09

npm包管理器工具

2024-06-20 08:06:04

2022-02-28 10:22:08

前端管理工具

2022-09-16 22:23:35

pnpmCLI軟件

2022-02-21 09:58:31

包管理器npmyarn

2025-09-15 00:00:01

2024-05-10 08:41:05

NPMYarn

2025-03-25 08:50:00

2025-03-17 00:21:00

2025-10-20 08:17:01

2025-07-07 06:21:46

2023-04-12 00:00:40

Node.jsMonoreponpm

2022-08-03 00:04:29

pnpmyarnnpm

2023-10-07 08:35:07

依賴注入Spring

2021-06-30 08:45:02

內(nèi)存管理面試

2025-04-21 04:00:00

2023-04-18 23:44:54

性能優(yōu)化開發(fā)preload

2021-02-25 07:24:35

pnpm包管理器前端

2024-12-04 13:54:19

pnpm存儲(chǔ)項(xiàng)目

2024-03-08 10:38:07

Vue響應(yīng)式數(shù)據(jù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

久久成人亚洲精品| 超鹏97在线| 亚洲欧美日本韩国| 福利在线一区二区三区| 一区二区成人在线视频| 色开心亚洲综合| 中文字幕日韩专区| 精品视频黄色| 亚洲欧洲中文| 中文字幕一区在线| 1024免费在线视频| 操日韩av在线电影| 亚洲一区欧美| 欧美,日韩,国产在线| 福利一区视频在线观看| 日韩新的三级电影| 国产视频999| 成人综合激情网| 污网站在线看| 中文字幕在线亚洲| 影音先锋日韩在线| 浮妇高潮喷白浆视频| 欧美性感一区二区三区| 人人爱人人干婷婷丁香亚洲| 国产亚洲欧美另类一区二区三区| av不卡免费电影| 婷婷免费在线视频| 欧美一级视频免费在线观看| 麻豆成人久久精品二区三区小说| 三上悠亚一区二区三区| 亚洲欧美日韩国产中文| 日韩久久视频| 免费黄色特级片| 日韩欧美www| 99久久99久久精品国产片桃花| 国产乱子伦精品视频| 日韩欧美精品中文字幕| xvideos.蜜桃一区二区| 日韩中文字幕亚洲精品欧美| 日本道精品一区二区三区| 亚洲精品一二三**| 亚洲精品无人区| 狠狠躁夜夜躁人人爽天天天天97| 亚洲我射av| 青少年xxxxx性开放hg| 91福利视频网站| 中文有码一区| 激情五月亚洲色图| 国产亚洲精品久久久久动| 99国产精品自拍| 最新中文字幕在线| 欧美激情中文字幕乱码免费| 国产美女精品一区二区三区| 日韩美女网站| 亚洲精品免费网站| 亚洲欧美成人一区二区三区| 国产精品国产三级在线观看| 女女同性女同一区二区三区按摩| 欧美日精品一区视频| 日韩激情一区| 国产黄色片大全| 久久久久国产精品免费| 91视频.com| 久久精品嫩草影院| 日本老太婆做爰视频| 亚洲国产又黄又爽女人高潮的| 中日韩视频在线观看| 国模吧精品人体gogo| 成人黄色在线播放| 婷婷中文字幕一区三区| 国产精品午夜一区二区三区| 国产h色视频在线观看| 97人人爽人人喊人人模波多 | 欧美v在线观看| 日韩av影视在线| 日韩中文字幕一区二区三区| 精精国产xxxx视频在线| 九色91在线视频| 91精品午夜视频| 国产精品视区| 黄色网址在线免费播放| 久久综合久久久| 91麻豆精品91久久久久同性| 夜夜嗨一区二区| 麻豆网在线观看| 日本一区二区三区免费观看| 日韩精品一区二区在线观看| 老鸭窝91久久精品色噜噜导演| 麻豆视频在线观看免费网站| 欧美连裤袜在线视频| 日韩精品一区二区三区视频播放 | 亚洲丝袜一区在线| 高清在线不卡av| 欧美一区二区三区婷婷| 国产成人久久777777| 久久人人看视频| 一二三四社区欧美黄| 99视频精品全部免费在线视频| 蜜桃视频在线观看网站| 蜜桃av久久久亚洲精品| 亚洲国产私拍精品国模在线观看| 国产精品综合一区二区| 四虎国产精品永久在线国在线| 久久久久久久久久久久91| 国产精品久久久久一区二区| 图片区小说区国产精品视频| 极品少妇一区二区三区| 久久av色综合| youjizz.com在线观看| 海角国产乱辈乱精品视频| 一区二区免费视频| 欧美色图麻豆| 成人影院在线观看| www.亚洲视频.com| 4438全国成人免费| 在线中文字幕一区| 久草免费在线视频| 国产a级一级片| 国产成人a亚洲精品| 欧美色区777第一页| 国产乱码精品一区二区三区av | 亚洲图片欧美视频| 亚洲影视在线| 一二区成人影院电影网| 成全视频全集| 国产精品美女黄网| 日韩精品亚洲元码| 国产精品欧美一区喷水| 性xxxx欧美老肥妇牲乱| eeuss鲁一区二区三区| 91av资源网| 国产综合久久久久| 亚洲黄色片网站| 亚洲欧洲另类国产综合| 亚洲第一精品影视| 国产精品99| 在线免费国产视频| 波多野结衣激情| 日本人成精品视频在线| 91精品蜜臀在线一区尤物| 97se狠狠狠综合亚洲狠狠| 久久精品青草| 羞羞影院欧美| 美女的诞生在线观看高清免费完整版中文 | 中国china体内裑精亚洲片| 精品国产_亚洲人成在线| 久草在线资源视频在线观看| avtt综合网| 亚洲欧洲综合另类| 久久久久久久国产精品视频| 99久热re在线精品996热视频| 欧妇女乱妇女乱视频| 亚洲香蕉成人av网站在线观看| 欧美精品久久久久久久多人混战| 欧美性色综合网| 国产91在线播放| 国产精品乱码一区二区三区| 国产精品自产拍在线观看| 欧洲美女7788成人免费视频| 韩国一区二区电影| 91精品在线播放| 开心色怡人综合网站| 国产精品影片在线观看| 成人综合国产精品| 日韩亚洲不卡在线| 亚洲免费不卡| 亚洲自拍欧美另类| 亚洲午夜久久久影院伊人 | 美女福利一区二区| 一本色道久久综合亚洲精品不| 国产精品自产自拍| 亚洲成在人线免费| 欧美一区二区三区四区久久| 欧美猛男性生活免费| 国产视频综合在线| 日韩美女一区二区三区| 日韩偷拍自拍| 成人国产一区二区三区| 亚洲一区二区久久久久久| 日韩中文字在线| 欧美一级黄色片| 亚洲激情图片小说视频| 国产精品99久久不卡二区| 中文字幕一区二区精品区| 日韩三级不卡| 国产高清中文字幕在线| 波多野结衣在线网站| 免费av网页| 男人天堂成人在线| 亚洲免费视频播放| 国产伦精品一区二区三区视频免费 | 欧美激情亚洲激情| 麻豆影视在线观看_| 日韩视频在线观看国产| 91精品久久久久久久久青青| 久久久精品久久| 亚洲人在线观看| 精品久久久久久最新网址| 欧美日韩一区三区四区| 亚洲福利视频一区|