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 可以在发布包中出现
相关推荐
左左右右左右摇晃4 分钟前
Java 笔记--OOM产生原因以及解决方法
java·笔记
ShiJiuD6668889991 小时前
mysql 基础笔记一
数据库·笔记·mysql
2501_926978332 小时前
“术“与“道“的平衡---“缺失“与“完整”的统一
经验分享·笔记·ai写作
智者知已应修善业2 小时前
【51单片机用两个定时计数器级联实现定时】2023-04-12
c语言·经验分享·笔记·算法·51单片机
中屹指纹浏览器2 小时前
2026高并发多账号运营下指纹浏览器性能调优与工程化实践
经验分享·笔记
Amazing_Cacao2 小时前
工艺师初级|参数与风味对齐(精品可可,精品巧克力)
笔记·学习
Larry_Yanan3 小时前
Qt网络开发之基于 QWebEngine 实现简易内嵌浏览器
linux·开发语言·网络·c++·笔记·qt·学习
小陈phd4 小时前
多模态大模型学习笔记(二十一)—— 基于 Scaling Law方法 的大模型训练算力估算与 GPU 资源配置
笔记·深度学习·学习·自然语言处理·transformer