對于一個項目,常用的一些npm簡單命令包含的功能有:初始化一個文件夾( npm init ),下載npm模塊( npm install ),創(chuàng)建測試( npm test ) 和自定義腳本( npm run )。但是,進一步了解一些 npm 的使用技巧可以徹底改變你的日常開發(fā)任務。
注: 如果你需要關(guān)于初學npm的參考,可以參閱我們的初學者指南。如果你對 npm 和 Yarn 之間的差異感到困擾,可以參閱我們發(fā)表的文章:Yarn vs npm:你需要知道的一切
npm 文檔 和 CLI 命令行文檔 是非常不錯地的學習資料,但需要通過瀏覽器訪問,這并不是很方便。因而可以通過命令行快速獲取所有可選項:
npm help
|
此外,還能獲取特定 npm 命令的使用幫助:
npm help
|
例如:npm help install
另一種方式是通過下面的命令:
npm-h
|
npm 通過bash提供了命令自動完成功能(包括 Bash for Windows 10 ):
npm completion >> ~/.bashrc
|
重新加載shell配置文件:
source ~/.bashrc
|
現(xiàn)在,在終端注入 npm ins ,然后按下 tab 鍵就會出現(xiàn) install 了,不會再浪費時間去全部輸入了。
當你試圖安裝全部模塊時,類 Linux 系統(tǒng)可能會拋出權(quán)限錯誤,可以在npm命令之前添加 sudo 來執(zhí)行,但這是一個較危險的選擇。一個更高的解決方式是改變 npm 默認的模塊安裝目錄:
mkdir ~/.npm-global
|
使用適當?shù)奈谋揪庉嬈鲗⑾旅娴囊恍刑砑拥?~/.bashrc 或者 ~/.zshrc 文件中:
export PATH=
|
重新加載配置文件(source ~/.bashrc),然后重新安裝npm到用戶所屬路徑:
npm install -g npm
|
這也會更新npm。
你可以通過下面的命令顯示npm當前的版本:
npm -v
|
如果有需要,可以通過下面的命令更新npm:
npm install -g npm
|
當 Node 的主版本 released 之后,你也可能需要重新構(gòu)建 C++ 擴展:
npm rebuild
|
如果你需要管理多個版本的node.js和npm,可以考慮使用 n 或者 nvm。這有一篇關(guān)于 nvm 的文章:使用 nvm 安裝多版本的Node.js
使用 npm init 初始化一個新的項目,這會提示你關(guān)于項目的更多細節(jié),并創(chuàng)建一個 package.json 文件。
如果你厭倦了每次開始一個新的項目都需要重新輸入同樣的信息,可以使用 -y 標記表示你能接受 package.json 文件的一堆默認值:
npm init -y
|
或者你可以設(shè)置一些語義化的默認值:
npm config set init.author.name
|
到目前為止,npm上已經(jīng)有超過350000個模塊了,并且每天還在持續(xù)增長。盡管有很多非常棒的模塊,但是你還是想避免使用一些不受歡迎的、存在bug的或者無人維護的模塊。在 npmjs 和 Github 上搜索npm模塊是很實用但這還有一些其它選擇:
npms
npms 根據(jù)一個基于項目版本、模塊下載次數(shù)、新更新日期、提交頻率、測試覆蓋率、文檔、貢獻者數(shù)量、issues數(shù)、star數(shù)、forks數(shù)和作者在社區(qū)的地位的綜合測量分數(shù)進行模塊排名。
npm Discover
npm Discover 定位于快速搜索和其它模塊通常一起使用的模塊,如 body-parser 通常和Express一起使用。
Packages by PageRank
Packages by PageRank 按照模塊的谷歌排名進行搜索和排序。
Curated npm Lists
還一個選擇就是利用別人的搜索結(jié)果。當需要一個健壯的解決方案時,我經(jīng)常會參考 sindresorhus 的 Awesome Node.js。
你已經(jīng)安裝了一些模塊,看看都有啥:
npm list
|
(ls、la & ll 可以用作 list 的別名)
該命令會顯示所有模塊:(安裝的)模塊,子模塊以及子模塊的子模塊等。可以限制輸出的模塊層級:
npm list --depth=0
|
打開一個模塊的主頁:
npm home
|
這只有在你的系統(tǒng)能打開瀏覽器時有用–在服務端的系統(tǒng)上會失敗。同樣,可以打開一個模塊的 Github 倉庫:
npm repo
|
或者它的文檔:
npm docs
|
或者它目前的bugs列表:
npm bugs
|
npm list 會顯示和你已經(jīng)安裝地模塊的關(guān)聯(lián)模塊—這些沒有在 package.json文件中被引用。你可以單獨 npm uninstall 每一個模塊或者全部移除它們:
npm prune
|
如果安裝模塊時你添加了 –production 標記或者 NODE_ENV 被設(shè)置成 production,package.json 文件中被指定為 devDependencies 的模塊也會被移除。
默認情況下,當用 –save/-S 或者 –save-dev/-D 安裝一個模塊時,npm 通過脫字符(^)來限定所安裝模塊的主版本號。例如,當運行 npm update 時, ^1.5.1 允許安裝版本號大于 1.5.1 但小于 2.0.0 版本的模塊。
波浪號(~)字符是限定模塊的次要版本。例如,當運行 npm update 時, ~1.5.1 允許安裝版本號大于 1.5.1 但小于 1.6.0 版本的模塊。可以將需要安裝的模塊版本前綴默認設(shè)置成波浪號(~):
npm config set save-prefix=
|
對于那些偏執(zhí)的認為任何更新(模塊的行為)會破壞系統(tǒng)的人,可以配置npm僅安裝精確版本號的模塊:
npm config set save-exact
|
另一個選擇是,可以在項目中使用 shrinkwrap:
npm shrinkwrap
|
這會生成一個 shrinkwrap.json 文件,該文件包含了你正在使用的模塊的指定版本。當運行 npm install 時,該文件所指定的模塊版本會覆蓋 package.json 文件中所指定的版本。
怎么知道一個模塊已經(jīng)更新了呢?我之前的方式是先列舉出項目所依賴的模塊(npm list –depth=0),然后在 npmjs.com 上找到該模塊,手動檢查該模塊的版本是否已經(jīng)更新。這非常費時。幸運的是,有一個更簡單的方式:
npm outdated
|
或者 npm outdated -g 來查找全局模塊。
你也可以查看一個獨立模塊的當前版本:
npm list
|
也可以查看檢驗當前和歷史版本:
npm viewversions
|
npm view會顯示一個獨立模塊的所有信息,包括它的依賴、關(guān)鍵字、更新日期、貢獻者、倉庫地址和許可證等。
當你正在開發(fā)一個模塊時,會經(jīng)常想在其它項目中嘗試使用或者在任何一個目錄運行它(如果你的應用支持),這時沒必要將其發(fā)布到 npm,并全局安裝—僅需在該模塊所在目錄使用下面的命令:
npn link
|
該命令會為模塊在全局目錄下創(chuàng)建一個符號鏈接。可以通過下面的命令查看模塊引用:
npm list -g --depth=0
|
或者:
npm outdated -g
|
現(xiàn)在,就可以從命令行運行模塊或者通過 require 在任何項目中引入該模塊。
另一個選擇是,可以通過文件路徑在 package.json 文件中聲明對該模塊的依賴:
"dependencies"
|
本站文章版權(quán)歸原作者及原出處所有 。內(nèi)容為作者個人觀點, 并不代表本站贊同其觀點和對其真實性負責,本站只提供參考并不構(gòu)成任何投資及應用建議。本站是一個個人學習交流的平臺,網(wǎng)站上部分文章為轉(zhuǎn)載,并不用于任何商業(yè)目的,我們已經(jīng)盡可能的對作者和來源進行了通告,但是能力有限或疏忽,造成漏登,請及時聯(lián)系我們,我們將根據(jù)著作權(quán)人的要求,立即更正或者刪除有關(guān)內(nèi)容。本站擁有對此聲明的最終解釋權(quán)。