我用的是Windows 10, Node 5.6.0和npm 3.6.0。我试图安装角材料和mdi到我的工作文件夹。NPM安装角材质mdi错误:

+-- angular@1.5.0

+-- UNMET PEER DEPENDENCY angular-animate@^1.5.0

+-- UNMET PEER DEPENDENCY angular-aria@^1.5.0

+-- angular-material@1.0.6

+-- UNMET PEER DEPENDENCY angular-messages@^1.5.0 `-- mdi@1.4.57

npm WARN enoent ENOENT: no such file or directory, open
'C:\Users\xxxxx\Desktop\ngClassifieds\package.json' 

npm WARN angular-material@1.0.6 requires a peer of
angular-animate@^1.5.0 but none was installed. 

npm WARN angular-material@1.0.6 requires a peer of angular-aria@^1.5.0
but none was installed. 

npm WARN angular-material@1.0.6 requires a peer of
angular-messages@^1.5.0 but none was installed.

如何解决这个问题来安装AngularJS材质和MDI ?


当前回答

当包中指定的一个或多个模块的依赖关系时,抛出UNMET PEER DEPENDENCY错误。Json文件不满足。 仔细检查警告并更新包。Json文件的正确版本的依赖。

然后运行

rm -rf node_modules/
npm cache clean
npm install

这将正确安装所有所需的依赖项。

其他回答

Npm-install-peers对我很有用。

npm install -g npm-install-peers

在尝试修复依赖项上的安全漏洞问题时,也可能发生此问题。

以下是我所做的: 审计已安装的依赖项

npm audit

如果有可用的修复程序,运行以下程序将在大多数情况下修复问题:

npm audit fix

有些问题会有SEMVER警告,按照链接会给我们提示如何进行手动检查和/或下一步该做什么。

做了更多的研究后,我发现了这个命令:

npm upgrade

似乎npm审计修复没有考虑更新对等依赖,运行npm升级将修复未满足的对等依赖。 现在检查我们是否通过运行来解决这个问题:

npm list

这将为我们提供项目的所有依赖项,并警告我们任何未满足的peer deps错误。在大多数情况下,升级实际上比停留在你正在使用的包的旧版本要好,如果你没有安全漏洞问题,npm安装也是一个可行的选择。

当包中指定的一个或多个模块的依赖关系时,抛出UNMET PEER DEPENDENCY错误。Json文件不满足。 仔细检查警告并更新包。Json文件的正确版本的依赖。

然后运行

rm -rf node_modules/
npm cache clean
npm install

这将正确安装所有所需的依赖项。

编辑2020

从npm v7.0.0开始,npm自动安装对等依赖项。这是升级到v7的原因之一。

https://github.blog/2020-10-13-presenting-v7-0-0-of-the-npm-cli/

本页也很好地解释了对等依赖的基本原理。 https://github.com/npm/rfcs/blob/latest/implemented/0025-install-peer-deps.md


这个答案并不适用于所有情况,但如果你不能通过简单地输入npm install来解决这个错误 ,这些步骤可能会有所帮助。

假设你得到了这个错误。

UNMET PEER DEPENDENCY packageA@4.2.0

npm WARN packageB@3.3.0 requires a peer of packageA@^3.1.0 but none was installed.

这意味着您安装了packageA的4.2.0版本,但packageB@3.3.0需要版本3.x。x的包。(^的解释)

因此,您可以通过将packageA降级到3.x来解决这个错误。X,但通常您不希望降级包。 好消息是,在某些情况下,packageB只是跟不上packageA, packageB的维护者正在努力将packageA的对等依赖关系提高到4.x.x。 在这种情况下,你可以在npm或github中检查是否有更高版本的packageB需要packageA的4.2.0版本。

例如,进入发布页面

通常情况下,你会发现类似这样的依赖性变化。

packageB v4.0.0-beta.0

BREAKING CHANGE
package: requires packageA >= v4.0.0

如果在发布页面上没有找到任何内容,请转到issue页面,并通过关键字搜索issue,例如peer。你可能会找到有用的信息。

此时,您有两个选择。

升级到需要的版本 请暂时保留错误,等待稳定版本发布。

如果你选择option1: 在很多情况下,版本没有最新标签,因此不稳定。所以你必须检查在这次更新中有什么改变,并确保任何东西都不会崩溃。

如果你选择option2: 如果pakageA从版本3升级到版本4很简单,或者pakagb的维护者还没有测试pakageA的版本4,但说应该没有问题,那么您可以考虑留下这个错误。

在这两种情况下,最好彻底测试它是否没有破坏任何东西。

最后,如果你想知道为什么你必须手动做这样的事情,这个链接解释得很好。

可以通过全局安装UNMET依赖项来解决。

示例:NPM install -g @angular/common@4.4.6

逐个安装。 这对我很管用。