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 可以在发布包中出现
相关推荐
im_AMBER3 小时前
Leetcode 59 二分搜索
数据结构·笔记·学习·算法·leetcode
天殇凉4 小时前
AC自动机学习笔记
java·笔记·学习
AA陈超4 小时前
从0开始学习 **Lyra Starter Game** 项目
c++·笔记·学习·游戏·ue5·lyra
2301_800256117 小时前
第七章 空间存储与索引 知识点梳理3(空间填充曲线)
数据库·笔记·sql·postgresql
凉凉的知识库8 小时前
书海拾遗:《枪炮、病菌与钢铁》
笔记·电子书
im_AMBER8 小时前
算法笔记 16 二分搜索算法
c++·笔记·学习·算法
摇滚侠9 小时前
2025最新 SpringCloud 教程,Nacos-总结,笔记19
java·笔记·spring cloud
在逃热干面9 小时前
(笔记)获取终端输出保存到文件
java·笔记·spring
leoufung9 小时前
逆波兰表达式 LeetCode 题解及相关思路笔记
linux·笔记·leetcode
lingggggaaaa10 小时前
免杀对抗——C2远控篇&PowerShell&有无文件落地&C#参数调用&绕AMSI&ETW&去混淆特征
c语言·开发语言·笔记·学习·安全·microsoft·c#