国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

深挖 NPM 機(jī)制

JaysonWang / 2829人閱讀

摘要:可以通過查詢對(duì)映模塊的信息安裝機(jī)制輸入命令并敲下回車后,會(huì)經(jīng)歷如下幾個(gè)階段以為例執(zhí)行工程自身當(dāng)前工程如果定義了鉤子此時(shí)會(huì)被執(zhí)行。在以前會(huì)嚴(yán)格按照依賴樹的結(jié)構(gòu)進(jìn)行安裝,因此會(huì)造成模塊冗余。當(dāng)發(fā)現(xiàn)有重復(fù)模塊時(shí),則將其丟棄。

使用NPM安裝的時(shí)候會(huì)經(jīng)常出現(xiàn)包沖突(比如多個(gè)主模塊的子模塊版本不一致等),導(dǎo)致在開發(fā)過程中會(huì)遇到各種或大或小的問題。所有在這會(huì)介紹以下內(nèi)容:

NPM 主要安裝方式

NPM 包信息查詢

NPM 安裝機(jī)制(主要)


安裝&查詢命令

NPM 各種安裝方式

npm install packageName[@next | @versionNumber]

在 node_modules 中沒有指定模塊時(shí)安裝,(不檢查~/.npm目錄)

npm install packageName --f | -- force

一個(gè)模塊不管是否安裝過,npm都要 強(qiáng)制重新安裝

npm update packageName

如果遠(yuǎn)程版本較新、或者本地版本不存在時(shí)安裝

NPM 查詢服務(wù)

NPM通過registry的查詢服務(wù),從而知道每個(gè)模塊的最新版本。

可以通過 npm view packageName [version] 查詢對(duì)映模塊的信息


NPM 安裝機(jī)制

輸入 npm install 命令并敲下回車后,會(huì)經(jīng)歷如下幾個(gè)階段(以 npm 5.5.1 為例):

1. 執(zhí)行工程自身 preinstall

當(dāng)前 npm 工程如果定義了 preinstall 鉤子此時(shí)會(huì)被執(zhí)行。

2. 確定首層依賴模塊

首先需要做的是確定工程中的首層依賴,也就是 dependenciesdevDependencies 屬性中直接指定的模塊(假設(shè)此時(shí)沒有添加 npm install 參數(shù))。

工程本身是整棵依賴樹的根節(jié)點(diǎn),每個(gè)首層依賴模塊都是根節(jié)點(diǎn)下面的一棵子樹,npm 會(huì)開啟多進(jìn)程從每個(gè)首層依賴模塊開始逐步尋找更深層級(jí)的節(jié)點(diǎn)。

如果查詢node_modules目錄之中已經(jīng)存在指定模塊,那么不再重新安裝

3. 獲取模塊

獲取模塊是一個(gè)遞歸的過程,分為以下幾步:

獲取模塊信息

在下載一個(gè)模塊之前,首先要確定其版本,這是因?yàn)?package.json 中往往是 semantic version(semver,語義化版本)

此時(shí)如果版本描述文件(npm-shrinkwrap.json 或 package-lock.json)中有該模塊信息直接拿即可

如果沒有則從倉庫獲取(向registry查詢)。如 packaeg.json 中某個(gè)包的版本是 ^1.1.0,npm 就會(huì)去倉庫中獲取符合 1.x.x 形式的最新版本。

獲取模塊實(shí)體。

上一步會(huì)獲取到模塊的壓縮包地址(resolved 字段),npm 會(huì)用此地址檢查本地緩存,緩存中有就直接拿,如果沒有則從倉庫下載。

查找該模塊依賴

如果有依賴則回到第1步,如果沒有則停止。

4. 模塊扁平化(dedupe)

一步獲取到的是一棵完整的依賴樹,其中可能包含大量重復(fù)模塊。比如 A 模塊依賴于 loadsh,B 模塊同樣依賴于 lodash。在 npm3 以前會(huì)嚴(yán)格按照依賴樹的結(jié)構(gòu)進(jìn)行安裝,因此會(huì)造成模塊冗余。

npm3 版本 開始默認(rèn)加入了一個(gè) dedupe 的過程。它會(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 過程中被去掉。

比如

node-modules 下 foo 模塊依賴 lodash@^1.0.0,bar 模塊依賴 lodash@^1.1.0,則 ^1.1.0 為兼容版本。

而當(dāng) foo 依賴 lodash@^2.0.0,bar 依賴 lodash@^1.1.0,則依據(jù) semver 的規(guī)則,二者不存在兼容版本。會(huì)將一個(gè)版本放在 node_modules 中,另一個(gè)仍保留在依賴樹里。

舉個(gè)例子,假設(shè)一個(gè)依賴樹原本是這樣:

node_modules
-- foo
---- lodash@version1

-- bar
---- lodash@version2

假設(shè) version1 和 version2 是兼容版本,則經(jīng)過 dedupe 會(huì)成為下面的形式:

node_modules
-- foo

-- bar

-- lodash(保留的版本為兼容版本)

假設(shè) version1 和 version2 為非兼容版本,則后面的版本保留在依賴樹中:

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 過程完成。

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://m.specialneedsforspecialkids.com/yun/54757.html

相關(guān)文章

  • 深挖 NPM 機(jī)制

    摘要:可以通過查詢對(duì)映模塊的信息安裝機(jī)制輸入命令并敲下回車后,會(huì)經(jīng)歷如下幾個(gè)階段以為例執(zhí)行工程自身當(dāng)前工程如果定義了鉤子此時(shí)會(huì)被執(zhí)行。在以前會(huì)嚴(yán)格按照依賴樹的結(jié)構(gòu)進(jìn)行安裝,因此會(huì)造成模塊冗余。當(dāng)發(fā)現(xiàn)有重復(fù)模塊時(shí),則將其丟棄。 使用NPM安裝的時(shí)候會(huì)經(jīng)常出現(xiàn)包沖突(比如多個(gè)主模塊的子模塊版本不一致等),導(dǎo)致在開發(fā)過程中會(huì)遇到各種或大或小的問題。所有在這會(huì)介紹以下內(nèi)容: NPM 主要安裝方式 ...

    godruoyi 評(píng)論0 收藏0
  • 深挖 NPM 機(jī)制

    摘要:可以通過查詢對(duì)映模塊的信息安裝機(jī)制輸入命令并敲下回車后,會(huì)經(jīng)歷如下幾個(gè)階段以為例執(zhí)行工程自身當(dāng)前工程如果定義了鉤子此時(shí)會(huì)被執(zhí)行。在以前會(huì)嚴(yán)格按照依賴樹的結(jié)構(gòu)進(jìn)行安裝,因此會(huì)造成模塊冗余。當(dāng)發(fā)現(xiàn)有重復(fù)模塊時(shí),則將其丟棄。 使用NPM安裝的時(shí)候會(huì)經(jīng)常出現(xiàn)包沖突(比如多個(gè)主模塊的子模塊版本不一致等),導(dǎo)致在開發(fā)過程中會(huì)遇到各種或大或小的問題。所有在這會(huì)介紹以下內(nèi)容: NPM 主要安裝方式 ...

    Code4App 評(píng)論0 收藏0
  • 2018年,前端應(yīng)該怎么學(xué)?

    摘要:未來一個(gè)大的趨勢(shì)就是前端開發(fā)的效果,正無限逼近原生效果同時(shí)一些大廠也在紛紛提前布局了,之前驚艷四方的天貓?jiān)煳锕?jié)淘寶造物節(jié)風(fēng)靡朋友圈的怎么做的如果我們要在這波浪潮上取得先機(jī),那么就必須提前學(xué)習(xí)。我個(gè)人想學(xué)習(xí)的框架是天貓的。 面向2018年,我覺得前端有這么三個(gè)方向可以突破 前端邏輯層(包括三大框架,webpack,前端數(shù)據(jù)管理) 前端交互層(包括css3,canvas,svg,vr...

    AnthonyHan 評(píng)論0 收藏0
  • 【Filecoin源碼倉庫全解析】第三章(下):存儲(chǔ)提供方(礦工)的配置操作

    摘要:我們將在下一章源碼倉庫全解析第四章下存儲(chǔ)需求方的配置操作中重點(diǎn)介紹存儲(chǔ)需求方用戶的配置操作,并反過來驗(yàn)證第三章中存儲(chǔ)礦工后續(xù)挖取新塊的過程,幫助大家融會(huì)貫通,并在工程上驗(yàn)證整個(gè)挖礦行為的生命周期。目前已成為華中區(qū)最大最具影響力的垂直媒體。 不好意思,這篇加了點(diǎn)八卦: 本來是不太想說這事的,從18年看到現(xiàn)在,不少見圈里的朋友和友商互相吐槽乃至攻擊...最近還鬧得比較大。這里說兩句:區(qū)塊鏈...

    曹金海 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<