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://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