Yarn是什么
yarn是一个新的JS包管理工具,正如官方文档里所说,yarn是为了弥补npm的一些缺陷而出现的。
npm的缺陷:
- npm install的时候巨慢,安装包不快/连续
- 同一个项目,安装的时候无法保持一致性。由于package.json文件中版本号的特点,下列三个版本号在安装时代表不同的含义:
版本号 | 含义 |
---|---|
“5.0.3” | 特指该版本 |
“~5.0.3” | 5.0.X中最新的版本 |
“^5.0.3” | 5.X.X中最新的版本 |
这就容易造成,同一个项目,有的同事是OK的,有的同事会因为安装的版本 不一样而出现bug。
- 安装时,包会在同一时间下载和安装,中途如果包抛出了一个错误,npm会继续下载和安装包,同时把所有的日志输出到终端。关于错误包的错误信息会在一大堆打印的log中丢失,很难注意到实际发生的错误。
yran的优点
- 速度快,主要是两个方面:
并行安装:yarn同步执行所有安装任务
离线模式:如果该包之前已经安装过,yarn再次安装时就会从缓存里获取 - 安装版本统一
为了防止拉取到不同的版本,yarn有一个锁定文件yarn.lock。该文件记录了被确切安装的模块的版本号。每次只要更新了一个模块,yarn.lock也会随之更新,这样就保证了每次拉取到同一个项目依赖时,使用的都是一样的模块版本。npm其实也有办法实现使用相同版本的包,但是需要开发者执行npm shrinkwrap命令,这个命令会生成一个锁定文件npm-shrinkwrap.json,同yarn.lock一个道理。yarn和npm的区别就是,yarn是默认生成的. - 更简洁的输出
yarn会直观的打印出必要的信息,也提供了一些命令供开发者查询额外的安装信息 - 多注册来源处理
所有的依赖包,不管被不同的库间接关联引用多少次,安装这个包时,只会从一个注册来源去安装,防止出现混乱。 - 更好的语义化
yarn改变了一些npm命令的名称,如yarn add/remove,比npm install/uninstall要更清晰。
yarn和npm命令的对比
npm(V5) | yarn |
---|---|
npm install | yarn install |
yarn install --flat | |
yarn install --har | |
npm install --no-package-lock | yarn install --no-lockfile |
yarn install --pure-lockfile | |
npm install [package] | yarn add [package] |
npm install [package] --save-dev | yarn add [package] --dev |
yarn add [package] --peer | |
npm install [package] --save-optional | yarn add [package] --optional |
npm install [package] --save-exact | yarn add [package] --exact |
yarn add [package] --tilde | |
npm install [package] --global | yarn global add [package] |
npm update --global | yarn global upgrade |
npm rebuild | yarn install --force |
npm uninstall [package] | yarn remove [package] |
npm cache clean | yarn cache clean [package] |
rm -rf node_modules && npm install | yarn upgrade |
关于npm5
npm5做了一些如下的改进:
1.新增了类似于yarn.lock的package-lock.json
2.git依赖支持优化
之前的版本,如果将本地目录作为依赖来安装,将会把文件目录作为副本拷贝到nodemodules中。而在npm5中,将改为使用创建symlinks的方式来实现(使用本地tarball包除外),而不再执行文件拷贝。这将会提升安装速度。目前yarn还不支持。