gpt4 book ai didi

npm - package.lock.json 文件的正确用法是什么,它到底在什么时候起作用

转载 作者:行者123 更新时间:2023-12-05 02:07:28 24 4
gpt4 key购买 nike

package.lock.json 文件的具体用途是什么?我读过它,但它令人困惑。

  1. 假设我执行 npm install 以便它会创建一个 package.lock.json 文件,而下次我执行 npm install,它会保留与 package.lock.json 文件中提到的相同包的安装吗?

  2. 假设我的 package.json 文件中有一个定义为 "^1.0.0" 的包版本,并且 npm 中有一个新版本可用注册表。它会在我执行 npm install 时更新包,还是会与 package.json 中的内容保持一致?

  3. 有没有什么简单的方法可以用确切的包版本号更新 package.json 文件,而无需手动一一更新?我想保持包的版本相同,以便下次任何人安装 npm 时,他们应该得到完全相同的包。需要一个发布分支

实际上,我需要 package.lock.json 文件的原始定义,但我发现其行为不一致。

我尝试使用 NPM CI 但它失败并显示错误 node_gyp needs python https://github.com/nodejs/node-gyp/issues/1977

最佳答案

package.lock.json文件的具体用途是什么?

Ans: 该文件用于描述最初生成的确切树,即最初用于安装的依赖项的版本(注意:如果 package. json 或 node_modules 由 npm 修改)

来源:https://docs.npmjs.com/configuring-npm/package-lock-json.html

现在回答您的具体问题:

  1. 假设我执行 npm install 以便它创建一个 package.lock.json 文件,下次我执行 npm install 时,将它保留了 package.lock.json 文件中提到的相同包的安装?

    这里的简单答案是:是

    当您最初执行 npm install 时,您指定包名称。 npm 将创建 node_modules 文件夹和 package-lock.json 文件,并添加包含用于安装的版本的包条目。下次当你执行 npm install 时,如果没有指定包,它不会更新你的任何包,即使使用 caret (^) 符号也是如此,因为这次 npm 将查看 package-lock。 json 文件(因为它存在于那里),它将安装在 (package-lock.json) 文件中指定的相同版本。

  2. 假设我的 package.json 文件中有一个定义为 "^1.0.0" 的包版本,并且 npm 中有一个新版本可用注册表。它会在我安装 npm 时更新包,还是会与 package.json 中的内容保持一致?

    如第一个问题中所述,如果目录中存在 package-lock.json,则不会。仅当目录中不存在 package-lock.json 文件和 node_modules 文件夹时,才会更新包。

  3. 有没有什么简单的方法可以用确切的包版本号更新 package.json 文件,而无需手动一一更新?我想保持包的版本不变,以便下次任何人执行 npm install 时,他们应该得到完全相同的包。需要一个发布分支

    使用 npm ci 是一个很好的做法,但您也可以使用 npm update,这会将依赖项更新到其最新的次要版本,并且您的 package.json 以及 package-lock.json 文件也将被更新

对于生产,它的首选方式是使用最初使用的相同版本的依赖项。在这种情况下,最好有 package-lock.json 文件,所以在 dockerizing 应用程序的情况下,当您执行 npm install 时,它将安装package-lock.json

中使用的版本的依赖关系

关于npm - package.lock.json 文件的正确用法是什么,它到底在什么时候起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61766031/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com