[轉(zhuǎn)]NPM 技巧

原文:https://www.shiyanlou.com/questions/6521

對(duì)于一個(gè)項(xiàng)目,常用的一些npm簡(jiǎn)單命令包含的功能有:初始化一個(gè)文件夾( npm init )屎慢,下載npm模塊( npm install )缩焦,創(chuàng)建測(cè)試( npm test ) 和自定義腳本( npm run )勾给。但是句占,進(jìn)一步了解一些 npm 的使用技巧可以徹底改變你的日常開(kāi)發(fā)任務(wù)。
注: 如果你需要關(guān)于初學(xué)npm的參考憎妙,可以參閱我們的初學(xué)者指南甚纲。如果你對(duì) npm 和 Yarn 之間的差異感到困擾口锭,可以參閱我們發(fā)表的文章:Yarn vs npm:你需要知道的一切

  1. 獲取幫助
    npm 文檔 和 CLI 命令行文檔 是非常不錯(cuò)地的學(xué)習(xí)資料,但需要通過(guò)瀏覽器訪問(wèn),這并不是很方便鹃操。因而可以通過(guò)命令行快速獲取所有可選項(xiàng):
    npm help

此外韭寸,還能獲取特定 npm 命令的使用幫助:
npm help <command>

例如:npm help install

另一種方式是通過(guò)下面的命令:
npm <command> -h

  1. npm 命令自動(dòng)完成
    npm 通過(guò)bash提供了命令自動(dòng)完成功能(包括 Bash for Windows 10 ):
    npm completion >> ~/.bashrc//or Z shellnpm completion >> ~/.zshrc

重新加載shell配置文件:
source ~/.bashrc

現(xiàn)在,在終端注入 npm ins荆隘,然后按下 tab鍵就會(huì)出現(xiàn) install了恩伺,不會(huì)再浪費(fèi)時(shí)間去全部輸入了。
3.修復(fù)全局模塊的權(quán)限
當(dāng)你試圖安裝全部模塊時(shí)椰拒,類 Linux 系統(tǒng)可能會(huì)拋出權(quán)限錯(cuò)誤晶渠,可以在npm命令之前添加 sudo 來(lái)執(zhí)行,但這是一個(gè)較危險(xiǎn)的選擇燃观。一個(gè)更高的解決方式是改變 npm 默認(rèn)的模塊安裝目錄:
mkdir ~/.npm-globalnpm config set prefix '~/.npm-global'

使用適當(dāng)?shù)奈谋揪庉嬈鲗⑾旅娴囊恍刑砑拥絶/.bashrc
或者~/.zshrc
文件中:
export PATH="$HOME/.npm-global/bin:$PATH"

重新加載配置文件(source ~/.bashrc
)褒脯,然后重新安裝npm到用戶所屬路徑:
npm install -g npm

這也會(huì)更新npm。
4.持續(xù)更新npm
你可以通過(guò)下面的命令顯示npm當(dāng)前的版本:
npm -v

如果有需要仪壮,可以通過(guò)下面的命令更新npm:
npm install -g npm

當(dāng) Node 的主版本 released 之后,你也可能需要重新構(gòu)建 C++ 擴(kuò)展:
npm rebuild

如果你需要管理多個(gè)版本的node.js和npm胳徽,可以考慮使用 n 或者 nvm积锅。這有一篇關(guān)于 nvm 的文章:使用 nvm 安裝多版本的Node.js
5.定義默認(rèn)的 npm init
使用 npm init初始化一個(gè)新的項(xiàng)目,這會(huì)提示你關(guān)于項(xiàng)目的更多細(xì)節(jié)养盗,并創(chuàng)建一個(gè)package.json
文件缚陷。
如果你厭倦了每次開(kāi)始一個(gè)新的項(xiàng)目都需要重新輸入同樣的信息,可以使用-y
標(biāo)記表示你能接受package.json
文件的一堆默認(rèn)值:
npm init -y

或者你可以設(shè)置一些語(yǔ)義化的默認(rèn)值:
npm config set init.author.name <name>npm config set init.author.email <email>

6.更精準(zhǔn)的模塊搜索
到目前為止往核,npm上已經(jīng)有超過(guò)350000個(gè)模塊了箫爷,并且每天還在持續(xù)增長(zhǎng)。盡管有很多非常棒的模塊聂儒,但是你還是想避免使用一些不受歡迎的虎锚、存在bug的或者無(wú)人維護(hù)的模塊。在 npmjs 和 Github 上搜索npm模塊是很實(shí)用但這還有一些其它選擇:
npms
npms 根據(jù)一個(gè)基于項(xiàng)目版本衩婚、模塊下載次數(shù)窜护、最新更新日期、提交頻率非春、測(cè)試覆蓋率柱徙、文檔、貢獻(xiàn)者數(shù)量奇昙、issues數(shù)护侮、star數(shù)、forks數(shù)和作者在社區(qū)的地位的綜合測(cè)量分?jǐn)?shù)進(jìn)行模塊排名储耐。
npm Discover
npm Discover 定位于快速搜索和其它模塊通常一起使用的模塊羊初,如 body-parser 通常和Express一起使用。
Packages by PageRank
Packages by PageRank 按照模塊的谷歌排名進(jìn)行搜索和排序什湘。
Curated npm Lists
還一個(gè)選擇就是利用別人的搜索結(jié)果凳忙。當(dāng)需要一個(gè)健壯的解決方案時(shí)业踏,我經(jīng)常會(huì)參考 sindresorhus 的 Awesome Node.js
7.管理你的模塊
你已經(jīng)安裝了一些模塊涧卵,看看都有啥:
npm list

(ls勤家、la& ll可以用作 list的別名)
該命令會(huì)顯示所有模塊:(安裝的)模塊,子模塊以及子模塊的子模塊等柳恐》ゲ保可以限制輸出的模塊層級(jí):
npm list --depth=0

打開(kāi)一個(gè)模塊的主頁(yè):
npm home <package>

這只有在你的系統(tǒng)能打開(kāi)瀏覽器時(shí)有用--在服務(wù)端的系統(tǒng)上會(huì)失敗。同樣乐设,可以打開(kāi)一個(gè)模塊的 Github 倉(cāng)庫(kù):
npm repo <package>

或者它的文檔:
npm docs <package>

或者它目前的bugs列表:
npm bugs <package>

npm list
會(huì)顯示和你已經(jīng)安裝地模塊的關(guān)聯(lián)模塊---這些沒(méi)有在package.json
文件中被引用讼庇。你可以單獨(dú) npm uninstall每一個(gè)模塊或者全部移除它們:
npm prune

如果安裝模塊時(shí)你添加了--production
標(biāo)記或者NODE_ENV
被設(shè)置成 production,package.json
文件中被指定為 devDependencies的模塊也會(huì)被移除近尚。
8.鎖定依賴
默認(rèn)情況下蠕啄,當(dāng)用--save/-S
或者--save-dev/-D
安裝一個(gè)模塊時(shí),npm 通過(guò)脫字符(^)來(lái)限定所安裝模塊的主版本號(hào)戈锻。例如歼跟,當(dāng)運(yùn)行 npm update 時(shí), ^1.5.1 允許安裝版本號(hào)大于 1.5.1 但小于 2.0.0 版本的模塊格遭。
波浪號(hào)(~)字符是限定模塊的次要版本哈街。例如,當(dāng)運(yùn)行npm update
時(shí)拒迅, ~1.5.1 允許安裝版本號(hào)大于 1.5.1 但小于 1.6.0 版本的模塊骚秦。可以將需要安裝的模塊版本前綴默認(rèn)設(shè)置成波浪號(hào)(~):
npm config set save-prefix="~"

對(duì)于那些偏執(zhí)的認(rèn)為任何更新(模塊的行為)會(huì)破壞系統(tǒng)的人璧微,可以配置npm僅安裝精確版本號(hào)的模塊:
npm config set save-exact true

另一個(gè)選擇是作箍,可以在項(xiàng)目中使用 shrinkwrap:
npm shrinkwrap

這會(huì)生成一個(gè)shrinkwrap.json
文件,該文件包含了你正在使用的模塊的指定版本前硫。當(dāng)運(yùn)行 npm install 時(shí)蒙揣,該文件所指定的模塊版本會(huì)覆蓋package.json
文件中所指定的版本。

  1. 找出過(guò)時(shí)的模塊
    怎么知道一個(gè)模塊已經(jīng)更新了呢开瞭?我之前的方式是先列舉出項(xiàng)目所依賴的模塊(npm list --depth=0
    )懒震,然后在npmjs.com
    上找到該模塊,手動(dòng)檢查該模塊的版本是否已經(jīng)更新嗤详。這非常費(fèi)時(shí)个扰。幸運(yùn)的是,有一個(gè)更簡(jiǎn)單的方式:
    npm outdated

或者npm outdated -g
來(lái)查找全局模塊葱色。
你也可以查看一個(gè)獨(dú)立模塊的當(dāng)前版本:
npm list <package>

也可以查看檢驗(yàn)當(dāng)前和歷史版本:
npm view <package> versions

npm view <package>
會(huì)顯示一個(gè)獨(dú)立模塊的所有信息递宅,包括它的依賴、關(guān)鍵字、更新日期办龄、貢獻(xiàn)者烘绽、倉(cāng)庫(kù)地址和許可證等。
10.使用開(kāi)發(fā)中的模塊
當(dāng)你正在開(kāi)發(fā)一個(gè)模塊時(shí)俐填,會(huì)經(jīng)常想在其它項(xiàng)目中嘗試使用或者在任何一個(gè)目錄運(yùn)行它(如果你的應(yīng)用支持)安接,這時(shí)沒(méi)必要將其發(fā)布到 npm,并全局安裝---僅需在該模塊所在目錄使用下面的命令:
npn link

該命令會(huì)為模塊在全局目錄下創(chuàng)建一個(gè)符號(hào)鏈接英融≌甸埽可以通過(guò)下面的命令查看模塊引用:
npm list -g --depth=0

或者:
npm outdated -g

現(xiàn)在,就可以從命令行運(yùn)行模塊或者通過(guò) require 在任何項(xiàng)目中引入該模塊驶悟。
另一個(gè)選擇是胡野,可以通過(guò)文件路徑在package.json
文件中聲明對(duì)該模塊的依賴:
"dependencies": { "myproject": "file:../myproject/"}

參考
10 Tips and Tricks That Will Make You an npm Ninja
轉(zhuǎn)載自:dwqs/blog
文章地址:https://github.com/dwqs/blog/issues/40

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市痕鳍,隨后出現(xiàn)的幾起案子硫豆,更是在濱河造成了極大的恐慌,老刑警劉巖笼呆,帶你破解...
    沈念sama閱讀 206,311評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件熊响,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡抄邀,警方通過(guò)查閱死者的電腦和手機(jī)耘眨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門昼榛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)境肾,“玉大人,你說(shuō)我怎么就攤上這事胆屿“掠鳎” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 152,671評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵非迹,是天一觀的道長(zhǎng)环鲤。 經(jīng)常有香客問(wèn)我,道長(zhǎng)憎兽,這世上最難降的妖魔是什么冷离? 我笑而不...
    開(kāi)封第一講書人閱讀 55,252評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮纯命,結(jié)果婚禮上西剥,老公的妹妹穿的比我還像新娘。我一直安慰自己亿汞,他們只是感情好瞭空,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般咆畏。 火紅的嫁衣襯著肌膚如雪南捂。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 49,031評(píng)論 1 285
  • 那天旧找,我揣著相機(jī)與錄音溺健,去河邊找鬼。 笑死钦讳,一個(gè)胖子當(dāng)著我的面吹牛矿瘦,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播愿卒,決...
    沈念sama閱讀 38,340評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼缚去,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了琼开?” 一聲冷哼從身側(cè)響起易结,我...
    開(kāi)封第一講書人閱讀 36,973評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎柜候,沒(méi)想到半個(gè)月后搞动,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,466評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡渣刷,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評(píng)論 2 323
  • 正文 我和宋清朗相戀三年鹦肿,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片辅柴。...
    茶點(diǎn)故事閱讀 38,039評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡箩溃,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出碌嘀,到底是詐尸還是另有隱情涣旨,我是刑警寧澤,帶...
    沈念sama閱讀 33,701評(píng)論 4 323
  • 正文 年R本政府宣布股冗,位于F島的核電站霹陡,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏止状。R本人自食惡果不足惜烹棉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望怯疤。 院中可真熱鬧浆洗,春花似錦、人聲如沸旅薄。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,259評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至洛口,卻和暖如春矫付,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背第焰。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工买优, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人挺举。 一個(gè)月前我還...
    沈念sama閱讀 45,497評(píng)論 2 354
  • 正文 我出身青樓杀赢,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親湘纵。 傳聞我的和親對(duì)象是個(gè)殘疾皇子脂崔,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)梧喷,斷路器砌左,智...
    卡卡羅2017閱讀 134,599評(píng)論 18 139
  • 什么是 NPM npm之于Node,就像pip之于Python,gem之于Ruby,composer之于PHP铺敌。 ...
    ihoey閱讀 6,248評(píng)論 2 36
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,504評(píng)論 25 707
  • npm是什么 NPM的全稱是Node Package Manager汇歹,是隨同NodeJS一起安裝的包管理和分發(fā)工具...
    build1024閱讀 7,860評(píng)論 0 9
  • 《理性世界》
    小胖子祺哥閱讀 147評(píng)論 0 0