npm-shrinkwrap.json 与 package-lock.json 区别和联系

从 npm 版本看

package-lock.json 是 npm 5 的新特性,也不向前兼容,如果 npm 版本是 4 或以下,那还是使用 npm-shrinkwrap.json 吧

从 npm 处理机制来看

  1. 在一个项目里,如果本身不存在这两个文件,那么在运行 npm install 时,会自动生成一个 package-lock.json ,或者在初始化一个项目 npm init 时,也会生成 package-lock.json ,安装信息会依据该文件进行,而不是单纯按照 package.json ,这两个文件的优先级都比 package.json 高
  2. 如果项目两个文件都存在,那么安装的依赖是依据 npm-shrinkwrap.json 来的,而忽略 package-lock.json
  3. 运行命令 npm shrinkwrap 后,如果项目里不存在 package-lock.json ,那么会新建一个 npm-shrinkwrap.json 文件,如果存在 package-lock.json ,那么会把 package-lock.json 重命名为 npm-shrinkwrap.json

从文件更新来看

  1. npm-shrinkwrap.json 只会在运行 npm shrinkwrap 才会创建/更新
  2. package-lock.json 会在修改 pacakge.json 或者 node_modules 时就会自动产生或更新了。

从发布包来看

  1. package-lock.json 不会在发布包中出现,就算出现了,也会遭到 npm 的无视。
  2. npm-shrinkwrap.json 可以在发布包中出现
相关推荐
茴香豆的茴110 分钟前
转码刷 LeetCode 笔记[1]:3.无重复字符的最长子串(python)
笔记·算法·leetcode
lemon_sjdk1 小时前
java笔记——ConcurrentLinkedQueue
java·开发语言·笔记
明长歌1 小时前
【javascript】Reflect学习笔记
javascript·笔记·学习
YGY Webgis糕手之路1 小时前
Cesium 快速入门(二)底图更换
前端·经验分享·笔记·vue
analywize2 小时前
diffusion原理和代码延伸笔记1——扩散桥,GOUB,UniDB
人工智能·笔记·深度学习·机器学习·diffusion·扩散桥
YGY Webgis糕手之路2 小时前
Cesium 快速入门(七)材质详解
前端·经验分享·笔记·vue·web
MingYue_SSS3 小时前
【未解决】STM32无刷电机驱动电路问题记录
笔记·嵌入式硬件·学习
草莓熊Lotso3 小时前
【数据结构初阶】--二叉树(六)
c语言·数据结构·经验分享·笔记·其他
hdsoft_huge5 小时前
ESXI虚拟交换机 + H3C S5120交换机 + GR5200路由器组网笔记
笔记·智能路由器
YGY Webgis糕手之路5 小时前
Cesium 快速入门(八)Primitive(图元)系统深度解析
前端·经验分享·笔记·vue·web