为什么不能导入或要求对等依赖关系,即使它存在于父模块中?



我正在尝试使用 npm peerDependencies但似乎没有什么像宣传的那样有效。我错过了什么?

设置是,我有两个模块,modplugin,它们都依赖于 npm 的外部模块。 mod声明了对plugin和外部模块的硬依赖关系,插件声明了对等依赖关系,以便访问父模块正在使用的版本。

这些文件如下所示:

~/plugin/package.json:
    {
      "name": "plugin",
      "version": "1.0.0",
      "main": "index.js",
      "peerDependencies": {
        "pad-right": "^0.2.2"
      }
    }
~/plugin/index.js
    var peerDependency = require('pad-right')
    module.exports = 'this is a plugin'
~/mod/package.json:
    {
      "name": "mod",
      "version": "1.0.0",
      "main": "index.js",
      "dependencies": {
        "pad-right": "^0.2.2",
        "plugin": "../plugin"
      }
    }
~/mod/index.js:
    var hardDependency = require('pad-right')
    var plugin = require('plugin')

正如我从文档和示例中了解到的那样,我认为这应该是使用对等依赖项的标准方式,并且在任一目录中运行npm install都不会给出任何错误或警告。

但是,当我在mod文件夹中运行 webpack 时,我收到以下错误:

ERROR in ../plugin/index.js
Module not found: Error: Can't resolve 'pad-right' in '~/plugin'
 @ ../plugin/index.js 1:21-41
 @ ./index.js

这里出了什么问题,webpack 不应该使用父模块mod模块的对等依赖来解决plugin内部的 require 语句吗?

Gah,看起来这是一个边缘情况,只影响通过文件系统在本地相互引用的模块。

解决方案显然是添加以下内容:

    resolve: {
        alias: {
            'pad-right': path.resolve('node_modules', 'pad-right'),
        },
    },

到您的 webpack 配置。(或者尝试resolve.symlinks: false,它解决了我发布的最小重现代码中的问题,但不能解决我实际项目中的问题(。

关于该问题的文章

相关内容

  • 没有找到相关文章

最新更新