从npm处迁移过来多许多用户来说是一个相对简单的过程。yarn能想npm一样定制相同的package.json
,并能够从npm仓库下载任意的包
如果你想要在已存在的npm项目中使用yarn,运行yarn即可,其默认运行的是yarn install:
yarn
这将使用Yarn的与npm的分辨率算法兼容( .)的分辨率算法去部署node_modules文件夹。
如果出现错误,请查看已存在的问题或将其报告给
当你运行yarn
或 yarn add <package>时,将会在包的根目录下生成
yarn.lock文档。你不需要去读或者理解这个文档,只要在源码控制中进行检查即可。当其他人使用yarn来替代npm时,
文档将保证他们精确地得到与你相同的依赖yarn.lock
在大多数例子中,第一次运行yarn
or yarn add就能成功。但是在一些例子中,
package.json
中的信息不够明确去排除依赖,且会与yarn选择依赖的明确方式产生冲突。这种情况经常发生在一些大项目中,npm install经常失败,导致开发人员要经常地移除node_modules
文件夹去从头开始构建。如果这个情况发生,尽量在转换成yarn之前使用npm去使依赖的版本更加明确
在yarn的1.7.0版本之后,能够使用yarn去import npm生成给yarn的来解决上面的问题
这个项目的其他开发人员还是能够继续使用npm,不需要让这个项目的每个人都同时转换。使用yarn的开发人员都会得到与他人相同的配置,使用npm的可能会有稍微的不同,这是npm有意导致的。
之后,如果你认为yarn不适合你,你仍能够回去使用npm,并不需要做任何的变化。如果这个项目没有人需要使用yarn,那么你就可以删除你的yarn.lock文档,但是这不是必须要做的。
如果你正使用npm-shrinkwrap.json
文档,要注意你可能会导致一系列不同的依赖。yarn不支持npm-shrinkwrap.json,因为它没有足够的信息去支持yarn更多的确定性算法。如果你正在使用
npm-shrinkwrap.json
,那么将这个项目的所有人同时转成使用yarn将更加容易。只要将npm-shrinkwrap.json
删除并检查新创建的yarn.lock
即可。
CLI commands comparison 两者的cli对比:
npm (v5) | Yarn |
---|---|
npm install | yarn install |
(N/A) | yarn install --flat |
(N/A) | yarn install --har |
npm install --no-package-lock | yarn install --no-lockfile |
(N/A) | yarn install --pure-lockfile |
npm install [package] | yarn add [package] |
npm install [package] --save-dev | yarn add [package] --dev |
(N/A) | yarn add [package] --peer |
npm install [package] --save-optional | yarn add [package] --optional |
npm install [package] --save-exact | yarn add [package] --exact |
(N/A) | yarn add [package] --tilde |
npm install [package] --global | yarn global add [package] |
npm update --global | yarn global upgrade |
npm rebuild | yarn add --force |
npm uninstall [package] | yarn remove [package] |
npm cache clean | yarn cache clean [package] |
rm -rf node_modules && npm install | yarn upgrade |
npm version major | yarn version --major |
npm version minor | yarn version --minor |
npm version patch | yarn version --patch |