NodeJS之npm、cnpm、npx、yarn


一、npm

1,概念

  npm 是 Node.js 官方提供的包管理工具,他已經成了 Node.js 包的標准發布平台,用於 Node.js 包的發布、傳播、依賴控制。npm 提供了命令行工具,使你可以方便地下載、安裝、升級、刪除包,也可以讓你作為開發者發布並維護包。
  npm 之於 Node.js ,就像 Maven之於java,pip 之於 Python, gem 之於 Ruby, pear 之於 PHP 。

2,常用命令

npm install npm@latest -g    自我更新

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的詳述,點擊這里


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM