这个文档很难回答我的问题。我不明白这些解释。有人能用更简单的话说吗?如果很难选择简单的单词,可以举个例子吗?
EDIT还添加了peerDependencies,它密切相关,可能会引起混淆。
这个文档很难回答我的问题。我不明白这些解释。有人能用更简单的话说吗?如果很难选择简单的单词,可以举个例子吗?
EDIT还添加了peerDependencies,它密切相关,可能会引起混淆。
当前回答
从属关系项目需要运行的依赖项,如提供从代码调用的函数的库。它们是以过渡方式安装的(如果A依赖于B依赖于C,则在A上安装npm将安装B和C)。示例:lodash:您的项目调用一些lodash函数。
devDependencies您只需要在开发或发布过程中使用的依赖项,例如将代码编译为javascript、测试框架或文档生成器的编译器。它们不是以过渡方式安装的(如果A依赖于B,则dev依赖于C,npm安装在A上将只安装B)。示例:grut:您的项目使用grut来构建自己。
对等依赖关系项目在父项目中挂钩或修改的依赖项,通常是其他库或工具的插件。这只是一个检查,确保父项目(将依赖于您的项目的项目)依赖于您所连接的项目。因此,如果你制作了一个插件C,将功能添加到库B中,那么制作项目a的人需要依赖于B,如果他们依赖于C。未安装它们(除非npm<3),只检查它们。示例:grut:您的项目为grut添加了功能,并且只能用于使用grut的项目。
本文档很好地解释了对等依赖关系:https://nodejs.org/en/blog/npm/peer-dependencies/
此外,随着时间的推移,npm文档得到了改进,现在对不同类型的依赖关系有了更好的解释:https://github.com/npm/cli/blob/latest/docs/content/configuring-npm/package-json.md#devdependencies
其他回答
如果不想安装devDependencies,可以使用npm install--production
我找到了一个简单的解释。
简短回答:
从属关系“……是您的项目真正需要能够在生产中工作的那些。”
devDependencies“…是您在开发过程中需要的。”
对等依赖关系“如果要创建和发布自己的库,以便将其用作依赖项”
本帖中的更多详细信息:https://code-trotter.com/web/dependencies-vs-devdependencies-vs-peerdependencies
从属关系项目需要运行的依赖项,如提供从代码调用的函数的库。它们是以过渡方式安装的(如果A依赖于B依赖于C,则在A上安装npm将安装B和C)。示例:lodash:您的项目调用一些lodash函数。
devDependencies您只需要在开发或发布过程中使用的依赖项,例如将代码编译为javascript、测试框架或文档生成器的编译器。它们不是以过渡方式安装的(如果A依赖于B,则dev依赖于C,npm安装在A上将只安装B)。示例:grut:您的项目使用grut来构建自己。
对等依赖关系项目在父项目中挂钩或修改的依赖项,通常是其他库或工具的插件。这只是一个检查,确保父项目(将依赖于您的项目的项目)依赖于您所连接的项目。因此,如果你制作了一个插件C,将功能添加到库B中,那么制作项目a的人需要依赖于B,如果他们依赖于C。未安装它们(除非npm<3),只检查它们。示例:grut:您的项目为grut添加了功能,并且只能用于使用grut的项目。
本文档很好地解释了对等依赖关系:https://nodejs.org/en/blog/npm/peer-dependencies/
此外,随着时间的推移,npm文档得到了改进,现在对不同类型的依赖关系有了更好的解释:https://github.com/npm/cli/blob/latest/docs/content/configuring-npm/package-json.md#devdependencies
依赖项:项目/包需要在生产环境中工作的包。
devDependencies:您的项目/包在开发时需要工作但在生产中不需要的包(例如:测试包)
peerDependencies:您的项目/包需要与之协同工作(与它们“协同工作”)或作为基础的包,主要用于开发插件/组件以了解您的插件/组件应该与哪个版本的“主”包协同工作(例如:React 16)
有些模块和软件包仅用于开发,而在生产中不需要。就像文档中所说的:
如果有人计划在他们的程序中下载并使用您的模块,那么他们可能不想或不需要下载并构建您使用的外部测试或文档框架。在这种情况下,最好在devDependencies散列中列出这些附加项。