package-lock.json 不会使 package.json 中所有 ^ 的使用无效吗?

问题描述

我正在尝试协调 package.json 中 ^ 字符的用途,以及它如何受 package-lock.json 的影响。例如,假设我运行 npm install johnny-dependency。现在我在 package.json 中列出了一个依赖项:

"johnny-dependency": "^1.2.0"

在 repo 实例化和第一个 npm install 时,将生成 package-lock.json,指定此包使用 1.2.0,并且还将指定 johnny-dependency 的依赖项的版本应该使用。

如果 package-lock.json 本质上锁定了版本,那么 package.json 中的 ^~ semvr 说明符的目的是什么?在问题 this answerWhy does “npm install” rewrite package-lock.json? 中,据说 package-lock.json 不再锁定根级依赖项。如果是这样,为什么将 package-lock.json 提交到源代码控制仍然是最佳实践?

我以前从未考虑过这个问题,我肯定遗漏了一些明显的东西吗?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)