Node.js中package.json中库的版本号(~和^)


Posted in Javascript onApril 02, 2019

~和^的区别

最近总是碰到一些问题, 在本地好好的, 在线上就出现了问题, 本地也一直复现不了, 后来把node_modules目录删除了之后, 重新安装, 就在本地复现了这个问题,可以看了git history, 并没有人修改package.json中的版本号,于是认真的了解了一下package.json中库的版本号;

~和^的区别

"babel-loader": "^7.1.1",
"body-parser": "~1.15.2"

npm install --save xxx, 会优先考虑使用 ^而不是~

以版本号x.y.z为例

x:主版本号, 当你做了不兼容的API修改

y:次版本号, 当你做了向下兼容的功能性问题

z:修订号, 当你做了向下兼容的问题修复

~x.y.z, 会更新到y最新的版本, 例如 body-parser: ~1.15.2, 这个库会去匹配到1.15.z的最新版本, 如果出现了1.16.0, 则不会自动升级
^x.y.z, 会更新到x的最新版本, 例如 babel-loader: ^7.1.1, 这个库会去匹配7.y.z的最新版本, 如果出现了8.1.1, 则不会自动升级

'~'(波浪符号):他会更新到当前minor version(也就是中间的那位数字)中最新的版本。放到我们的例子中就是:"exif-js": "~2.3.0",这个库会去匹配更新到2.3.x的最新版本,如果出了一个新的版本为2.4.0,则不会自动升级。波浪符号是曾经npm安装时候的默认符号,现在已经变为了插入符号。
'^'(插入符号): 这个符号就显得非常的灵活了,他将会把当前库的版本更新到当前major version(也就是第一位数字)中最新的版本。放到我们的例子中就是:"vue": "^2.2.2", 这个库会去匹配2.x.x中最新的版本,但是他不会自动更新到3.0.0。

可以参考npm官方给出的解释

^1.2.3 := >=1.2.3 <2.0.0
^0.2.3 := >=0.2.3 <0.3.0
^0.0.3 := >=0.0.3 <0.0.4

大多数情况下遵循这种版本号规则的依赖包都没问题, 但是npm是开源的世界, 并不是所有的都严格遵循这种规则, 所以会出现上述的问题;

为什么需要package锁

有如下几个可能原因, 在某些情况下, package.json是无法保证每个人自己电脑上执行的 npm install 后安装的依赖版本都是一样的

1.如果package.json中记录的依赖包的版本是一个版本范围, 一旦执行npm i 会导致这个包更新到最新版本

2.就算你依赖了一个固定版本的包(如A 1.1.1), 但你依赖的包A可能依赖其他的包B,而A在声明依赖时可能也使用了semser命名, 如 ^1.2.3, 如果包B release 了新版, 也会导致包B会安装到更新版本

3.不同人使用的npm程序的版本不同

如果依赖包的版本不一致, 会导致开发环境和生产环境产品不一致的行为; 或者导致不同团队成员之前也产品环境差异

如何解决包版本不一致的情况

1.npm 使用package-lock.json文件来解决这个问题

执行npm install会自动生成package.json文件, 只要执行普通的安装, 更新等可能会修改 package.json的npm命令, 都会自动同步修改package-lock.json文件

npm install xxx
npm rm xxx
npm update xxx

2.npm 还支持npm-shrinkwrap.json, 和package-lock.json功能完全一样

执行 npm shrinkwrap来生成npm-shrinkwrap.json

此命令将根据 package-lock.json 文件创建一个新的或覆盖已有的 npm-shrinkwrap.json 文件。 此命令创建和更新的文件将优先于任何其他现有或将有的 package-lock.json 文件。

3.使用yarn

使用yarn主要有一下优点

  • 快速: 会缓存它下载的每个包,无需重复下载;能并行化操作以最大资源利用率
  • 可靠:使用格式详尽而又简洁的 lockfile文件 和确定性算法来安装依赖,能够保证在一个系统上的运行的安装过程也会以同样的方式运行在其他系统上。
  • 安全: 安装包被执行前校验其完整性
  • yarn速度比npm快一些, yarn的锁文件是yarn.lock, 能解决包版本不一致的情况

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript与cookie 的问题详解
Nov 11 Javascript
JS获取随机数函数可自定义最小值最大值
May 08 Javascript
JavaScript中的console.group()函数详细介绍
Dec 29 Javascript
js完美实现@提到好友特效(兼容各大浏览器)
Mar 16 Javascript
jquery判断复选框是否选中进行答题提示特效
Dec 10 Javascript
jQuery.ajax 跨域请求webapi设置headers的解决方案
Aug 08 Javascript
基于AngularJS实现iOS8自带的计算器
Sep 12 Javascript
Bootstrap select多选下拉框实现代码
Dec 23 Javascript
js解决软键盘遮挡输入框的问题分享
Dec 19 Javascript
如何对react hooks进行单元测试的方法
Aug 14 Javascript
Antd中单个DatePicker限定时间输入范围操作
Oct 29 Javascript
记录一次websocket封装的过程
Nov 23 Javascript
基于Vue插入视频的2种方法小结
Apr 02 #Javascript
vue踩坑记-在项目中安装依赖模块npm install报错
Apr 02 #Javascript
小程序实现自定义导航栏适配完美版
Apr 02 #Javascript
es6 symbol的实现方法示例
Apr 02 #Javascript
微信小程序设置全局请求URL及封装wx.request请求操作示例
Apr 02 #Javascript
Vue CLI 3.x 自动部署项目至服务器的方法
Apr 02 #Javascript
Vue 组件修改根实例的数据的方法
Apr 02 #Javascript
You might like
具有时效性的php加密解密函数代码
2013/06/19 PHP
PHP内核探索之变量
2015/12/22 PHP
JavaScript For Beginners(转载)
2007/01/05 Javascript
加随机数引入脚本不让浏览器读取缓存
2014/09/04 Javascript
jQuery UI插件自定义confirm确认框的方法
2015/03/20 Javascript
jQuery中attr()与prop()函数用法实例详解(附用法区别)
2015/12/29 Javascript
一篇文章掌握RequireJS常用知识
2016/01/26 Javascript
Bootstrap表单简单实现代码
2017/03/06 Javascript
jQuery开源组件BootstrapValidator使用详解
2017/06/29 jQuery
Javascript实现找不同色块的游戏
2017/07/17 Javascript
webpack进阶——缓存与独立打包的用法
2017/08/02 Javascript
基于Vue单文件组件详解
2017/09/15 Javascript
使用layer模态框给新页面传值的方法
2019/09/27 Javascript
vue界面发送表情的实现代码
2020/09/11 Javascript
JS实现购物车基本功能
2020/11/08 Javascript
[03:55]显微镜下的DOTA2特别篇——430灰烬之灵神级操作
2014/06/24 DOTA
Python常见数据结构详解
2014/07/24 Python
用python做一个搜索引擎(Pylucene)的实例代码
2017/07/05 Python
Python中标准库OS的常用方法总结大全
2017/07/19 Python
Pyqt实现无边框窗口拖动以及窗口大小改变
2018/04/19 Python
pytorch 转换矩阵的维数位置方法
2018/12/08 Python
python3中类的继承以及self和super的区别详解
2019/06/26 Python
PyCharm使用Docker镜像搭建Python开发环境
2019/12/26 Python
pandas中的ExcelWriter和ExcelFile的实现方法
2020/04/24 Python
python批量修改文件名的示例
2020/09/27 Python
利用CSS3动画实现圆圈由小变大向外扩散的效果实例
2018/09/10 HTML / CSS
SmartBuyGlasses丹麦:网上购买名牌太阳镜、眼镜和隐形眼镜
2016/10/01 全球购物
施华洛世奇水晶荷兰官方网站:SWAROVSKI荷兰
2017/05/12 全球购物
Ever New加拿大官网:彰显女性美
2018/10/05 全球购物
马来西亚户外装备商店:PTT Outdoor
2019/07/13 全球购物
八年级音乐教学反思
2014/01/09 职场文书
驾驶员安全责任书
2014/07/22 职场文书
自主招生自荐信怎么写
2015/03/24 职场文书
钢琴师观后感
2015/06/12 职场文书
领导离职感言
2015/08/03 职场文书
python识别围棋定位棋盘位置
2021/07/26 Python