摘要:可以通過(guò)查詢(xún)對(duì)映模塊的信息安裝機(jī)制輸入命令并敲下回車(chē)后,會(huì)經(jīng)歷如下幾個(gè)階段以為例執(zhí)行工程自身當(dāng)前工程如果定義了鉤子此時(shí)會(huì)被執(zhí)行。在以前會(huì)嚴(yán)格按照依賴(lài)樹(shù)的結(jié)構(gòu)進(jìn)行安裝,因此會(huì)造成模塊冗余。當(dāng)發(fā)現(xiàn)有重復(fù)模塊時(shí),則將其丟棄。
使用NPM安裝的時(shí)候會(huì)經(jīng)常出現(xiàn)包沖突(比如多個(gè)主模塊的子模塊版本不一致等),導(dǎo)致在開(kāi)發(fā)過(guò)程中會(huì)遇到各種或大或小的問(wèn)題。所有在這會(huì)介紹以下內(nèi)容:
NPM 主要安裝方式
NPM 包信息查詢(xún)
NPM 安裝機(jī)制(主要)
安裝&查詢(xún)命令NPM 各種安裝方式
npm install packageName[@next | @versionNumber]
在 node_modules 中沒(méi)有指定模塊時(shí)安裝,(不檢查~/.npm目錄)
npm install packageName --f | -- force
一個(gè)模塊不管是否安裝過(guò),npm都要 強(qiáng)制重新安裝
npm update packageName
如果遠(yuǎn)程版本較新、或者本地版本不存在時(shí)安裝
NPM 查詢(xún)服務(wù)
NPM通過(guò)registry的查詢(xún)服務(wù),從而知道每個(gè)模塊的最新版本。
可以通過(guò) npm view packageName [version] 查詢(xún)對(duì)映模塊的信息
NPM 安裝機(jī)制輸入 npm install 命令并敲下回車(chē)后,會(huì)經(jīng)歷如下幾個(gè)階段(以 npm 5.5.1 為例):
1. 執(zhí)行工程自身 preinstall
當(dāng)前 npm 工程如果定義了 preinstall 鉤子此時(shí)會(huì)被執(zhí)行。
2. 確定首層依賴(lài)模塊
首先需要做的是確定工程中的首層依賴(lài),也就是 dependencies 和 devDependencies 屬性中直接指定的模塊(假設(shè)此時(shí)沒(méi)有添加 npm install 參數(shù))。
工程本身是整棵依賴(lài)樹(shù)的根節(jié)點(diǎn),每個(gè)首層依賴(lài)模塊都是根節(jié)點(diǎn)下面的一棵子樹(shù),npm 會(huì)開(kāi)啟多進(jìn)程從每個(gè)首層依賴(lài)模塊開(kāi)始逐步尋找更深層級(jí)的節(jié)點(diǎn)。
如果查詢(xún)node_modules目錄之中已經(jīng)存在指定模塊,那么不再重新安裝
3. 獲取模塊
獲取模塊是一個(gè)遞歸的過(guò)程,分為以下幾步:
獲取模塊信息
在下載一個(gè)模塊之前,首先要確定其版本,這是因?yàn)?package.json 中往往是 semantic version(semver,語(yǔ)義化版本)
此時(shí)如果版本描述文件(npm-shrinkwrap.json 或 package-lock.json)中有該模塊信息直接拿即可
如果沒(méi)有則從倉(cāng)庫(kù)獲?。ㄏ騬egistry查詢(xún))。如 packaeg.json 中某個(gè)包的版本是 ^1.1.0,npm 就會(huì)去倉(cāng)庫(kù)中獲取符合 1.x.x 形式的最新版本。
獲取模塊實(shí)體。
上一步會(huì)獲取到模塊的壓縮包地址(resolved 字段),npm 會(huì)用此地址檢查本地緩存,緩存中有就直接拿,如果沒(méi)有則從倉(cāng)庫(kù)下載。
查找該模塊依賴(lài)
如果有依賴(lài)則回到第1步,如果沒(méi)有則停止。
4. 模塊扁平化(dedupe)
一步獲取到的是一棵完整的依賴(lài)樹(shù),其中可能包含大量重復(fù)模塊。比如 A 模塊依賴(lài)于 loadsh,B 模塊同樣依賴(lài)于 lodash。在 npm3 以前會(huì)嚴(yán)格按照依賴(lài)樹(shù)的結(jié)構(gòu)進(jìn)行安裝,因此會(huì)造成模塊冗余。
從 npm3 版本 開(kāi)始默認(rèn)加入了一個(gè) dedupe 的過(guò)程。它會(huì)遍歷所有節(jié)點(diǎn),逐個(gè)將模塊放在根節(jié)點(diǎn)下面,也就是 node-modules 的第一層。當(dāng)發(fā)現(xiàn)有重復(fù)模塊時(shí),則將其丟棄。
這里需要對(duì)重復(fù)模塊進(jìn)行一個(gè)定義,它指的是模塊名相同且 semver 兼容。每個(gè) semver 都對(duì)應(yīng)一段版本允許范圍,如果兩個(gè)模塊的版本允許范圍存在交集,那么就可以得到一個(gè)兼容版本,而不必版本號(hào)完全一致,這可以使更多冗余模塊在 dedupe 過(guò)程中被去掉。
比如
node-modules 下 foo 模塊依賴(lài) lodash@^1.0.0,bar 模塊依賴(lài) lodash@^1.1.0,則 ^1.1.0 為兼容版本。
而當(dāng) foo 依賴(lài) lodash@^2.0.0,bar 依賴(lài) lodash@^1.1.0,則依據(jù) semver 的規(guī)則,二者不存在兼容版本。會(huì)將一個(gè)版本放在 node_modules 中,另一個(gè)仍保留在依賴(lài)樹(shù)里。
舉個(gè)例子,假設(shè)一個(gè)依賴(lài)樹(shù)原本是這樣:
node_modules
-- foo
---- lodash@version1
-- bar
---- lodash@version2
假設(shè) version1 和 version2 是兼容版本,則經(jīng)過(guò) dedupe 會(huì)成為下面的形式:
node_modules
-- foo
-- bar
-- lodash(保留的版本為兼容版本)
假設(shè) version1 和 version2 為非兼容版本,則后面的版本保留在依賴(lài)樹(shù)中:
node_modules
-- foo
-- lodash@version1
-- bar
---- lodash@version2
5. 安裝模塊
這一步將會(huì)更新工程中的 node_modules,并執(zhí)行模塊中的生命周期函數(shù)(按照 preinstall、install、postinstall 的順序)。
6. 執(zhí)行工程自身生命周期
當(dāng)前 npm 工程如果定義了鉤子此時(shí)會(huì)被執(zhí)行(按照 install、postinstall、prepublish、prepare 的順序)。
最后一步是生成或更新版本描述文件,npm install 過(guò)程完成。
End文章分享同步于: https://github.com/zhongmeizh...
參考
阮一峰的個(gè)人博客
npm實(shí)現(xiàn)原理
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/103089.html
摘要:可以通過(guò)查詢(xún)對(duì)映模塊的信息安裝機(jī)制輸入命令并敲下回車(chē)后,會(huì)經(jīng)歷如下幾個(gè)階段以為例執(zhí)行工程自身當(dāng)前工程如果定義了鉤子此時(shí)會(huì)被執(zhí)行。在以前會(huì)嚴(yán)格按照依賴(lài)樹(shù)的結(jié)構(gòu)進(jìn)行安裝,因此會(huì)造成模塊冗余。當(dāng)發(fā)現(xiàn)有重復(fù)模塊時(shí),則將其丟棄。 使用NPM安裝的時(shí)候會(huì)經(jīng)常出現(xiàn)包沖突(比如多個(gè)主模塊的子模塊版本不一致等),導(dǎo)致在開(kāi)發(fā)過(guò)程中會(huì)遇到各種或大或小的問(wèn)題。所有在這會(huì)介紹以下內(nèi)容: NPM 主要安裝方式 ...
摘要:可以通過(guò)查詢(xún)對(duì)映模塊的信息安裝機(jī)制輸入命令并敲下回車(chē)后,會(huì)經(jīng)歷如下幾個(gè)階段以為例執(zhí)行工程自身當(dāng)前工程如果定義了鉤子此時(shí)會(huì)被執(zhí)行。在以前會(huì)嚴(yán)格按照依賴(lài)樹(shù)的結(jié)構(gòu)進(jìn)行安裝,因此會(huì)造成模塊冗余。當(dāng)發(fā)現(xiàn)有重復(fù)模塊時(shí),則將其丟棄。 使用NPM安裝的時(shí)候會(huì)經(jīng)常出現(xiàn)包沖突(比如多個(gè)主模塊的子模塊版本不一致等),導(dǎo)致在開(kāi)發(fā)過(guò)程中會(huì)遇到各種或大或小的問(wèn)題。所有在這會(huì)介紹以下內(nèi)容: NPM 主要安裝方式 ...
摘要:未來(lái)一個(gè)大的趨勢(shì)就是前端開(kāi)發(fā)的效果,正無(wú)限逼近原生效果同時(shí)一些大廠也在紛紛提前布局了,之前驚艷四方的天貓?jiān)煳锕?jié)淘寶造物節(jié)風(fēng)靡朋友圈的怎么做的如果我們要在這波浪潮上取得先機(jī),那么就必須提前學(xué)習(xí)。我個(gè)人想學(xué)習(xí)的框架是天貓的。 面向2018年,我覺(jué)得前端有這么三個(gè)方向可以突破 前端邏輯層(包括三大框架,webpack,前端數(shù)據(jù)管理) 前端交互層(包括css3,canvas,svg,vr...
摘要:我們將在下一章源碼倉(cāng)庫(kù)全解析第四章下存儲(chǔ)需求方的配置操作中重點(diǎn)介紹存儲(chǔ)需求方用戶的配置操作,并反過(guò)來(lái)驗(yàn)證第三章中存儲(chǔ)礦工后續(xù)挖取新塊的過(guò)程,幫助大家融會(huì)貫通,并在工程上驗(yàn)證整個(gè)挖礦行為的生命周期。目前已成為華中區(qū)最大最具影響力的垂直媒體。 不好意思,這篇加了點(diǎn)八卦: 本來(lái)是不太想說(shuō)這事的,從18年看到現(xiàn)在,不少見(jiàn)圈里的朋友和友商互相吐槽乃至攻擊...最近還鬧得比較大。這里說(shuō)兩句:區(qū)塊鏈...
閱讀 871·2021-10-11 10:59
閱讀 2806·2019-08-30 15:43
閱讀 2136·2019-08-30 11:08
閱讀 1657·2019-08-29 15:20
閱讀 1016·2019-08-29 13:53
閱讀 494·2019-08-26 13:24
閱讀 1644·2019-08-26 13:24
閱讀 2828·2019-08-26 12:08