一、npm
1,概念
2,常用命令
npm help 查看npm命令列表
npm -l 查看各個命令的簡單用法
npm -v 查看npm的版本
npm config list -l 查看npm的配置
npm init -y 初始化項目
npm config set registry http://registry.npm.taobao.org 設置為淘寶鏡像源
npm list 列出安裝的模塊
npm info 查看模塊具體信息
npm install/i $module@$version [-global/-g] [--save]/[-S] [--save-dev]/[-D] [-f] 安裝包
全局安裝會安裝到node安裝目錄的node_modules並且安裝的模塊命令在系統環境變量中,而本地安裝只會安裝到本項目的node_modules中。
[--save]/[-S]代表是否將依賴信息添加到package.json的dependencies中。
[--save-dev]/[-D]代表將依賴信息以開發模式添加到package.json的devDependencies中。
-f代表無論以前是否安裝過某模塊,都重新安裝
npm uninstall $module 刪除包,參數同install
npm update 更新包,參數同install
npm install 安裝 dependencies 字段和 devDependencies 字段中的所有模塊
npm [run] $script 執行package.json 文件scripts 字段中的腳本
npm bin 列出當前項目可執行腳本目錄
npm config set prefix "E:/nodejs/npm_global" 修改npm全局包路徑
npm config set cache "E:/nodejs/npm_global/npm_cache" 修改npm全局包緩存路徑
查看則是把set改成get
二、cnpm
1,概念
淘寶團隊做的國內鏡像,因為npm的服務器位於國外可能會影響安裝。
2,命令
npm install cnpm -g --registry=https://registry.npm.taobao.org 安裝cnpm
npm config get registry 查看正在使用的鏡像地址
npm config set registry https://registry.npm.taobao.org 設置新鏡像地址
cnpm其他命令同npm
三、npx
1,概念
npx是npm5.2之后發布的一個命令。官網說它是“execute npm package binaries”,就是執行npm依賴包的二進制文件,簡而言之,就是我們可以使用npx來執行各種命令。使用npx可以在命令行直接執行本地已安裝的依賴包命令,不用在scripts腳本寫入命令,也不用麻煩的去找本地腳本。使用npx,可以在不全局安裝依賴包的情況下,運行命令,而且運行后不會污染全局環境。
2,運行原理
step1:去node_modules/.bin路徑檢查npx后的命令是否存在,找到之后執行;
step2:找不到,就去環境變量$PATH里面,檢查npx后的命令是否存在,找到之后執行;
step3:還是找不到,自動下載一個臨時的依賴包最新版本在一個臨時目錄,然后再運行命令,運行完之后刪除,不污染全局環境。
四、yarn
1,概念
Yarn是由Facebook、Google、Exponent 和 Tilde 聯合推出了一個新的 JS 包管理工具 ,正如官方文檔中寫的,Yarn 是為了彌補 npm 的一些缺陷而出現的。
2,對比npm
npm缺點:
1:npm install的時候巨慢。特別是新的項目拉下來要等半天,刪除node_modules,重新install的時候依舊如此。
2:同一個項目,安裝的時候無法保持一致性。由於package.json文件中版本號的特點,下面三個版本號在安裝的時候代表不同的含義。
-"5.0.3" : 表示安裝指定的5.0.3版本;
-"~5.0.3" :表示安裝5.0.x中最新的版本;
-"^5.0.3" :表示安裝5.X.X中最新的版本,
3:安裝的時候,包會在同一時間下載和安裝,中途某個時候,一個包拋出錯誤,但是npm會繼續下載和安裝包。因為npm會把所有日志輸出到終端,有關錯誤包的信息就會在一大堆npm打印的警告中丟失掉,並且你不會注意到實際發生的錯誤。
yarn優點:
1:並行安裝:無論 npm 還是 Yarn 在執行包的安裝時,都會執行一系列任務。npm 是按照隊列執行每個 package,也就是說必須要等到當前 package 安裝完成之后,才能繼續后面的安裝。而 Yarn 是同步執行所有任務,提高了性能。
2:離線模式:如果之前已經安裝過一個軟件包,用Yarn再次安裝時之間從緩存中獲取,就不用像npm那樣再從網絡下載了。
3:安裝版本統一:為了防止拉取到不同的版本,Yarn 有一個鎖定文件 (lock file) 記錄了被確切安裝上的模塊的版本號。每次只要新增了一個模塊,Yarn 就會創建(或更新)yarn.lock 這個文件。這么做就保證了,每一次拉取同一個項目依賴時,使用的都是一樣的模塊版本。npm 其實也有辦法實現處處使用相同版本的 packages,但需要開發者執行 npm shrinkwrap 命令。這個命令將會生成一個鎖定文件,在執行 npm install 的時候,該鎖定文件會先被讀取,和 Yarn 讀取 yarn.lock 文件一個道理。npm 和 Yarn 兩者的不同之處在於,Yarn 默認會生成這樣的鎖定文件,而 npm 要通過 shrinkwrap 命令生成 npm-shrinkwrap.json 文件,只有當這個文件存在的時候,packages 版本信息才會被記錄和更新。
3:更簡潔的輸出:npm 的輸出信息比較冗長。在執行 npm install <package> 的時候,命令行里會不斷地打印出所有被安裝上的依賴。相比之下,Yarn 簡潔太多:默認情況下,結合了 emoji直觀且直接地打印出必要的信息,也提供了一些命令供開發者查詢額外的安裝信息。
4:多注冊來源處理:所有的依賴包,不管他被不同的庫間接關聯引用多少次,安裝這個包時,只會從一個注冊來源去裝,要么是 npm 要么是 bower, 防止出現混亂不一致。
5:更好的語義化: yarn改變了一些npm命令的名稱,比如 yarn add/remove,感覺上比 npm 原本的 install/uninstall 要更清晰。
npm5.0的改進:
默認新增了類似yarn.lock的 package-lock.json;
git 依賴支持優化:這個特性在需要安裝大量內部項目(例如在沒有自建源的內網開發),或需要使用某些依賴的未發布版本時很有用。在這之前可能需要使用指定 commit_id 的方式來控制版本。
文件依賴優化:在之前的版本,如果將本地目錄作為依賴來安裝,將會把文件目錄作為副本拷貝到 node_modules 中。而在 npm5 中,將改為使用創建 symlinks 的方式來實現(使用本地 tarball 包除外),而不再執行文件拷貝。這將會提升安裝速度。目前yarn還不支持。
總結:
在npm5.0之前,yarn的優勢特別明顯。但是在npm之后,通過以上一系列對比,我們可以看到 npm5 在速度和使用上確實有了很大提升,值得嘗試,不過還沒有超過yarn。
3,命令
另一篇博客有關於yarn的詳述,點擊這里。