用yarn/npm管理依赖包的版本

在package.json中基本上都是用^来锁定版本的,^只能锁定大版本,比如^2.6.1,只能确定安装的是>2.0.0,<2.9.9的,如果已经更新到了2.9.1版本,就会下载2.9.1版本。这样就会存在安装的版本和开发时版本不一致的问题,很可能其他同事的项目都没有问题,只有你的项目启动或者页面有奇怪的报错。

为了解决这个问题 ,我们可以将npm 换成yarn

mac安装yarn命令

brew install yarn

如果你在使用nvm,为了防止nvm对node的管理作用,安装时使用

brew install yarn --without-node

yarn install 会自动生成一个yarn.lock文件,其中声明了每个安装包现在安装的版本,以后在每次用yarn重新安装依赖的时候,都会优先下载yarn.lock中的版本。这样就能保证每个同事在同一个版本上开发了。

那么如果我们要手动更新某个包的版本呢?比如package.json中element-ui的版本是^2.6.1,我们想使用2.9.1版本。

执行命令:yarn upgrade element-ui@2.9.1 

package.json中版本会指定2.9.1,并且yarn.lock也会更新,这样其他同事在开发的时候,重新执行下yarn install,就会更新到指定的版本了。

 

当然,如果你还是想用npm完成锁定版本的功能,也是可以的,但是要使用5以上版本,并且npm install很慢,即使配置了淘宝源,还是很慢,所以我是放弃了。

试了下cnpm install,发现并没有生成packgae-lock.json文件,在网上查资料,说是cnpm install并不会生成lock文件,并且,就算项目中有lock文件,cnpm也不会读取这个文件,只会按package.json下载,所以cnpm 并不支持版本锁定。当然这只是道听途说,如果有人试过了还请留言告诉我,在这我就偷个懒了。因为实在太慢了,cnpm install 也是经常socket hang up.

posted @ 2019-06-17 16:09  如斯~  阅读(2110)  评论(0编辑  收藏  举报