npm 是什么? 如何安裝 node 應用?
npm是node.js的包管理工具,負責插件的更新、下載、卸載、發布和撤銷等,允許用戶從npm服務器上下載別人編寫的第三方包到本地使用,或者將自己編寫的包或命令行發布出去給別人使用。下載了node.js后,npm是其自帶的,直接使用npm命令行使用插件即可。
全局安裝和本地安裝的區別
npm install -g xxx
表示全局安裝一個node應用,可以在任何文件目錄下使用這個包的命令。本地安裝就是安裝到指定的文件目錄下,使用的時候只有在這個目錄下才能使用。
--save 和 --save-dev 有什么區別?
-
npm install --save app
安裝的是正式使用時依賴的包,在package.json的dependencies參數里可以找到,也可簡寫成npm install -S app
-
npm install --save-dev app
安裝的是開發或者測試時依賴的包,在package.json的devDependencies參數里可以找到,也可簡寫成npm install -D app
package.json 有什么作用?
npm init
命令生成package.json文件,這個文件定義了項目所需的各種模板及相關配置信息。
{
"name": "my_package", //項目名稱
"version": "1.0.0", //項目版本號
"main": "index.js", //入口文件
// bin參數是{ 命令名:文件名 }的格式,指定了各個內部命令對應的可執行文件的位置,相當于在user.local/bin下創建一個快捷方式
// 執行`server`,`mock`或`server-mock`命令時,將運行對應文件(./bin/server)
// ./bin/server文件頭部需添加 #!/usr/bin/env node, 表示將以node運行這個文件
"bin":{
"server":"./bin/server",
"mock":"./bin/mock",
"server-mock":"./bin/server-mock"
},
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1", //一般默認一個test的空文件夾、用作寫測試代碼,`npm test`即可運行。
"make":"echo 'hello world!' " //自定義的命令名需加run才能與運行,`npm run make`
},
"keywords": [], //項目的關鍵詞。 一般用不到,發布npm才用得到。
"author": "candy", //作者名稱
"license": "ISC", //協議
"repository": { // 用來存放到 版本管理遠程服務。 發布npm才有用
"type": "git",
"url": "https://github.com/ashleygwilliams/my_package.git"
},
"dependencies": { // 正式使用時依賴的包, npm install --save xxx 生成
"my_dep": "^1.0.0"
},
"devDependencies" : {//開發或者測試時,依賴的包。npm install --save-dev xxx生成
"my_test_framework": "^3.1.0"
}
"bugs": { //同repository
"url": "https://github.com/ashleygwilliams/my_package/issues"
},
"homepage": "https://github.com/ashleygwilliams/my_package" //項目主頁、 發布才有用
}
nodule_modules的查找路徑是怎樣的?
比如需要查找的依賴包叫“easytpl”,它會先在當前目錄下查找node_module, 看有沒有easytpl文件夾(即easytpl包),如果有的話,會讀取easytpl文件夾下的package.json,找到里面的main參數,加載main里對應的路徑的文件。如果當前目錄下沒有node_module,或當前目錄下的node_module沒找到easytpl,便向上級目錄中查詢,直到系統根目錄。
npm3與 npm2相比有什么改進?yarn和 npm 相比有什么優勢?
npm3相比npm2主要改進了依賴管理方案
- npm2安裝依賴的時候比較簡單直接,直接按照包的依賴的樹形結構下載填充至本地目錄,缺陷在于太深的目錄樹結構會嚴重影響效率,甚至在window下可能會超出系統路徑限制的長度,另外有刪node_modules目錄經歷的可能都漫長的等待。
-
針對 npm2 的問題,npm3 加了點算法,直白的解釋就是:npm install 時會按照 package.json 里依賴的順序依次解析,遇到新的包就把它放在第一級目錄,后面如果遇到一級目錄已經存在的包,會先判斷版本,如果版本一樣則忽略,否則會按照 npm2 的方式依次掛在依賴包目錄下
在包版本差異化不太嚴重的情況下,這種構建方式會幾乎把所有包放在一級目錄下,很大程度下提升了效率以及節省了部分磁盤空間。
但是npm3又遇到了新問題,有可能開發環境和測試環境的node_modules的目錄結構不一樣,以及其他因素,faceboook開發了yarn來替代npm。 - yarn優點在于只要通過Yarn安裝過的套件都會在本地目錄產生Cache,也就是說只要安裝過依次,下次重新安裝都會從Cache重新讀取, 安裝速度會提升很多。