【问题标题】:how to make webpack use shared node modules in the parent directory如何让 webpack 使用父目录中的共享节点模块
【发布时间】:2017-09-12 22:36:22
【问题描述】:

我想使用保存在父目录中的共享节点模块。我有以下文件夹结构:

  • 父目录
    • node_modules
    • 公司
      • serverless.yml
      • handler.js
      • webpack.config

我必须使用 webpack 创建包并上传到aws-lamda。但是 webpack 正在寻找节点模块。但我收到以下错误:

Overriding the webpack directory in serverless-webpack since it uses v1 version of webpack...
cp: cannot stat 'node_modules/webpack': No such file or directory

如何让 webpack.config 指向父目录中的 node_modules?

【问题讨论】:

  • 你运行 npm install 没有出现任何错误吗?
  • 我想使用父目录中的共享节点模块
  • 这看起来不像是 webpack 错误,而是像 shell 脚本错误,你尝试 cp 一个不存在的文件。如果在当前目录的node_modules 中找不到父node_modules,webpack 也会很高兴地查看它,除非另有配置。你能告诉我们你正在运行的脚本吗?

标签: node.js webpack serverless-framework


【解决方案1】:

如果您阅读了 NodeJS require 文档,我们强烈建议您使用本地 node_modules 文件夹,即使您的包 require 具有相同的依赖项。

https://nodejs.org/api/modules.html#modules_loading_from_node_modules_folders

您也可以使用 NODE_PATH ,注意 require 将首先查看本地 node_modules 然后开始查看其他文件夹,因此请尝试删除本地 node_modules

如果 NODE_PATH 环境变量设置为以冒号分隔的绝对路径列表,则 Node.js 将在这些路径中搜索模块(如果在其他地方找不到它们)。 (注意:在 Windows 上,NODE_PATH 由分号而不是冒号分隔。)

由于 webpack 公开了许多模块解析选项https://webpack.github.io/docs/resolving.html

解析模块路径 为了解析一个模块,Resolve 首先从 Webpack 的上下文目录中收集模块的所有搜索目录。此过程类似于 node.js 解析过程,但搜索目录可使用配置选项 resolve.modulesDirectories 进行配置。除此之外,配置选项resolve.root中的目录被附加,配置选项resolve.fallback中的目录被附加。

【讨论】:

    猜你喜欢
    • 2017-11-29
    • 2020-02-26
    • 1970-01-01
    • 1970-01-01
    • 2018-01-27
    • 1970-01-01
    • 2018-10-14
    • 2016-05-18
    • 1970-01-01
    相关资源
    最近更新 更多