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 相关文章推荐
ext 列表页面关于多行查询的办法
Mar 25 Javascript
JQuery扩展插件Validate—4设置错误提示的样式
Sep 05 Javascript
Js判断参数(String,Array,Object)是否为undefined或者值为空
Nov 04 Javascript
jQuery中:first-child选择器用法实例
Dec 31 Javascript
JavaScript中将数组进行合并的基本方法讲解
Mar 07 Javascript
概述VUE2.0不可忽视的很多变化
Sep 25 Javascript
bootstrap3 dialog 更强大、更灵活的模态框
Apr 20 Javascript
JavaScript实现删除数组重复元素的5种常用高效算法总结
Jan 18 Javascript
使用proxy实现一个更优雅的vue【推荐】
Jun 19 Javascript
Layui给switch添加响应事件的例子
Sep 03 Javascript
解决vue+ element ui 表单验证有值但验证失败问题
Jan 16 Javascript
解决vue-cli输入命令vue ui没效果的问题
Nov 17 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生成自己的LOG文件
2006/10/09 PHP
php中get_object_vars()方法用法实例
2015/02/08 PHP
PHP中的traits简单使用实例
2015/05/13 PHP
thinkPHP简单实现多个子查询语句的方法
2016/12/05 PHP
一文掌握PHP Xdebug 本地与远程调试(小结)
2019/04/23 PHP
JavaScript 使用技巧精萃(.net html
2009/04/25 Javascript
JS获取dom 对象 ajax操作 读写cookie函数
2009/11/18 Javascript
jQuery 表格工具集
2010/04/25 Javascript
分享XmlHttpRequest调用Webservice的一点心得
2012/07/20 Javascript
javascript定义变量时有var和没有var的区别探讨
2014/07/21 Javascript
Javascript无参数和有参数类继承问题解决方法
2015/03/02 Javascript
jQuery DOM删除节点操作指南
2015/03/03 Javascript
jquery实现网站列表切换效果的2种方法
2016/08/12 Javascript
jQuery删除节点用法示例(remove方法)
2016/09/08 Javascript
微信小程序 支付功能开发错误总结
2017/02/21 Javascript
socket.io学习教程之基本应用(二)
2017/04/29 Javascript
jqueryUI tab标签页代码分享
2017/10/09 jQuery
vue forEach循环数组拿到自己想要的数据方法
2018/09/21 Javascript
详解微信小程序框架wepy踩坑记录(与vue对比)
2019/03/12 Javascript
使用Vant完成DatetimePicker 日期的选择器操作
2020/11/12 Javascript
谈谈Python进行验证码识别的一些想法
2016/01/25 Python
实例讲解Python中整数的最大值输出
2019/03/17 Python
记录Python脚本的运行日志的方法
2019/06/05 Python
关于python中密码加盐的学习体会小结
2019/07/15 Python
python 的 openpyxl模块 读取 Excel文件的方法
2019/09/09 Python
开启Django博客的RSS功能的实现方法
2020/02/17 Python
通过实例解析Python return运行原理
2020/03/04 Python
使用python批量转换文件编码为UTF-8的实现
2020/04/03 Python
Python-openCV开运算实例
2020/07/05 Python
Python中Selenium库使用教程详解
2020/07/23 Python
python Scrapy框架原理解析
2021/01/04 Python
使用Python封装excel操作指南
2021/01/29 Python
中海讯通笔试题
2015/09/15 面试题
教师个人成长总结
2015/02/11 职场文书
悬崖上的金鱼姬观后感
2015/06/15 职场文书
创业计划书之寿司
2019/07/19 职场文书