版本

ESLint 无法唯一确定插件…

症状

当使用旧版 ESLint 配置系统时,您可能在安装依赖项后运行 ESLint 时会看到此错误。

ESLint couldn't determine the plugin "${pluginId}" uniquely.

- ${filePath} (loaded in "${importerName}")
- ${filePath} (loaded in "${importerName}")
...

Please remove the "plugins" setting from either config or remove either plugin installation.

原因

ESLint 配置文件允许加载可能包含其他插件的插件。插件包可能被指定为您的包和一个或多个 ESLint 插件的依赖项。旧版 ESLint 配置文件可以使用extends来包含其他配置。这些配置可能依赖于插件以在配置中提供某些功能。

例如,如果您的配置依赖于eslint-plugin-a@2eslint-plugin-b@3,并且您扩展了依赖于eslint-plugin-a@1eslint-config-b,那么eslint-plugin-a包可能在磁盘上具有两个不同的版本。

  • node_modules/eslint-plugin-a
  • node_modules/eslint-plugin-b/node_modules/eslint-plugin-a

如果旧版 ESLint 配置系统看到这两个插件在多个位置存在且版本不同,它将不知道使用哪个。

请注意,此问题仅存在于旧版 eslintrc 配置中。新的“扁平化”配置系统让您自己import依赖项,从而无需 ESLint 尝试唯一确定它们的版本。

解决方案

此问题的常见解决方案包括

  • 将所有软件包的所有版本升级到最新版本
  • 运行npm dedupe或等效的包管理器命令来消除重复的软件包,如果它们的版本范围兼容
  • 使用overrides或等效的包管理器package.json字段,强制使用插件包的特定版本
    • 请注意,如果插件包在版本之间存在重大更改,这可能会导致 lint 出现错误

资源

有关更多信息,请参阅

更改语言