npm常用命令解析

酷越發表於2017-07-20

npm是什麼

NPM的全稱是Node Package Manager,是隨同NodeJS一起安裝的包管理和分發工具,它很方便讓JavaScript開發者下載、安裝、上傳以及管理已經安裝的包。

npm install 安裝模組

基礎語法

複製程式碼
npm install (with no args, in package dir)
npm install [<@scope>/]<name>
npm install [<@scope>/]<name>@<tag>
npm install [<@scope>/]<name>@<version>
npm install [<@scope>/]<name>@<version range>
npm install <tarball file>
npm install <tarball url>
npm install <folder>

alias: npm i
common options: [-S|--save|-D|--save-dev|-O|--save-optional] [-E|--save-exact] [--dry-run]
複製程式碼

安裝包,預設會安裝最新的版本

npm install gulp

安裝指定版本

npm install gulp@3.9.1

安裝包並將資訊保持到專案的package.json檔案中

專案對模組的依賴可以使用下面的 3 種方法來表示(假設當前版本號是 1.1.0 ):

  • 相容模組新發布的補丁版本:~1.1.0、1.1.x、1.1
  • 相容模組新發布的小版本、補丁版本:^1.1.0、1.x、1
  • 相容模組新發布的大版本、小版本、補丁版本:*、x

-S, --save 安裝包資訊將加入到dependencies(生產階段的依賴)

npm install gulp --save 或 npm install gulp -S

package.json 檔案的 dependencies 欄位:

"dependencies": {
    "gulp": "^3.9.1"
}

-D, --save-dev 安裝包資訊將加入到devDependencies(開發階段的依賴),所以開發階段一般使用它

npm install gulp --save-dev 或 npm install gulp -D

package.json 檔案的 devDependencies欄位:

"devDependencies": {
    "gulp": "^3.9.1"
}

-O, --save-optional 安裝包資訊將加入到optionalDependencies(可選階段的依賴)

npm install gulp --save-optional 或 npm install gulp -O

package.json 檔案的optionalDependencies欄位:

"optionalDependencies": {
    "gulp": "^3.9.1"
},

-E, --save-exact 精確安裝指定模組版本

npm install gulp --save-exact 或 npm install gulp -E

輸入命令npm install gulp -ES,留意package.json 檔案的 dependencies 欄位,以看出版本號中的^消失了

"dependencies": {
    "gulp": "3.9.1"
}

模組的依賴都被寫入了package.json檔案後,他人開啟專案的根目錄(專案開源、內部團隊合作),使用npm install命令可以根據dependencies配置安裝所有的依賴包

npm install

本地安裝(local)

npm install gulp

全域性安裝(global),使用 -g 或 --global

npm install gulp -g

npm ls 檢視安裝的模組

基礎語法

npm ls [[<@scope>/]<pkg> ...]

aliases: list, la, ll

檢視全域性安裝的模組及依賴 

npm ls -g 

npm uninstall 解除安裝模組 

基礎語法

npm uninstall [<@scope>/]<pkg>[@<version>]... [-S|--save|-D|--save-dev|-O|--save-optional]

aliases: remove, rm, r, un, unlink

如解除安裝開發版本的模組

npm uninstall gulp --save-dev

npm update 更新模組

基礎語法

npm update [-g] [<pkg>...]

npm outdated 檢查模組是否已經過時

基礎語法

npm outdated [[<@scope>/]<pkg> ...]

此命令會列出所有已經過時的包,可以及時進行包的更新

npm init 在專案中引導建立一個package.json檔案

安裝包的資訊可保持到專案的package.json檔案中,以便後續的其它的專案開發或者他人合作使用,也說package.json在專案中是必不可少的。

npm init [-f|--force|-y|--yes]

npm help 檢視某條命令的詳細幫助 

例如輸入npm help install,系統在預設的瀏覽器或者預設的編輯器中開啟本地nodejs安裝包的檔案/nodejs/node_modules/npm/html/doc/cli/npm-install.html

npm help <command>

npm root 檢視包的安裝路徑

輸出 node_modules的路徑

npm root [-g]

npm config 管理npm的配置路徑

基礎語法

複製程式碼
複製程式碼
npm config set <key> <value> [-g|--global]
npm config get <key>
npm config delete <key>
npm config list
npm config edit
npm get <key>
npm set <key> <value> [-g|--global]
複製程式碼
複製程式碼

對於config這塊用得最多應該是設定代理,解決npm安裝一些模組失敗的問題

例如我在公司內網,因為公司的防火牆原因,無法完成任何模組的安裝,這個時候設定代理可以解決

npm config set proxy=http://dev-proxy.oa.com:8080

又如國內的網路環境問題,某官方的IP可能被和諧了,幸好國內有好心人,搭建了映象,此時我們簡單設定映象

npm config set registry="http://r.cnpmjs.org"

npm cache 管理模組的快取

基礎語法

複製程式碼
npm cache add <tarball file>
npm cache add <folder>
npm cache add <tarball url>
npm cache add <name>@<version>

npm cache ls [<path>]

npm cache clean [<path>]
複製程式碼

最常用命令無非清除npm本地快取

npm cache clean

npm start 啟動模組

基礎語法

npm start [-- <args>]

該命令寫在package.json檔案scripts的start欄位中,可以自定義命令來配置一個伺服器環境和安裝一系列的必要程式,如

"scripts": {
    "start": "gulp -s"
}

如果package.json檔案沒有設定start,則將直接啟動node server.js

npm stop 停止模組

基礎語法

npm stop [-- <args>]

npm restart 重新啟動模組

基礎語法

npm restart [-- <args>]

關於npm package.json的語法

可參考《npm的package.json中文文件》,寫得非常詳細。

參考資料:

https://docs.npmjs.com/

https://segmentfault.com/a/1190000004221514

https://cnodejs.org/getstart

最近在瞭解node.js.發現這篇博文很實用,轉載於http://www.cnblogs.com/PeunZhang/p/5553574.html

 

轉:http://www.cnblogs.com/jiechen/p/5575899.html

相關文章