模块构建失败(来自 ./node_modules/mini-css-extract-plugin/dist/loader.js):

Module build failed (from ./node_modules/mini-css-extract-plugin/dist/loader.js):

我们正在将 CSS-loader 从 v0.28.11 迁移到 v3.1.0

我们有 2 个项目:

我们能够 运行 并成功构建项目 A。 但是,当我们尝试 运行 项目 B 时,我们收到项目 A 中 css 文件的依赖性错误。

ERROR in ./src/help/css/about.qcss
Module build failed (from ./node_modules/mini-css-extract-plugin/dist/loader.js):
ModuleNotFoundError: Module not found: Error: Can't resolve './Project/A/src/typography/css/qx-typography.css' in 'D:\Projects\B\src\help\css'
    at factory.create (D:\Projects\B\node_modules\webpack\lib\Compilation.js:823:10)
    at factory (D:\Projects\B\node_modules\webpack\lib\NormalModuleFactory.js:397:22)
    at resolver (D:\Projects\B\node_modules\webpack\lib\NormalModuleFactory.js:130:21)
    at asyncLib.parallel (D:\Projects\B\node_modules\webpack\lib\NormalModuleFactory.js:224:22)
    at D:\Projects\B\node_modules\neo-async\async.js:2830:7
    at D:\Projects\B\node_modules\neo-async\async.js:6877:13
    at normalResolver.resolve (D:\Projects\B\node_modules\webpack\lib\NormalModuleFactory.js:214:25)
    at doResolve (D:\Projects\B\node_modules\enhanced-resolve\lib\Resolver.js:184:12)
    at hook.callAsync (D:\Projects\rx\node_modules\enhanced-resolve\lib\Resolver.js:238:5)
    at _fn0 (eval at create (D:\Projects\B\node_modules\tapable\lib\HookCodeFactory.js:33:10), <anonymous>:15:1)
  1. 如果我们将项目 A 加载到 v3.1.0,将项目 B 加载到 v1.0.0css
  2. ,同样可以正常工作
  3. 但是,如果我们将两个项目 css-loader 版本都更改为 3.1.0
  4. ,则会出现编译时错误

我们应该能够 运行 并使用 CSS-loader 3.1.0

创建构建

出现此问题是因为 webpack resolve.alias not works

为了解决这个问题,我们可以使用相对路径。

就我而言

Currently, I am in Projects\B\src\help\css

and requiring file from node_Modules
/Project/A/src/typography/css/qx-typography.css

so my path be like (**Relative Path**)
../../../../node_modules/Project/A/src/typography/css/qx-typography.css";
Module build failed (from ./node_modules/mini-css-extract-plugin/dist/loader.js):

ModuleBuildError:模块构建失败(来自 ./node_modules/sass-loader/dist/cj s.js): 错误:缺少绑定 /home/user/frontloja/node_modul es/node-sass/vendor/ linux-x64-64/binding.node 节点 Sass 找不到您当前环境的绑定:Linux 64 位 Node.js 10.x 找到以下环境的绑定: - Linux 64 位 Node.js 12.x

在我的例子中,它发生在我将 ubuntu 18 更新为 20 之后,所以我这样做了

  1. 删除或重命名 node_modules
  2. 然后使用 npm 或 yarn install 重新安装

错误:./src/styles.css 模块构建失败(来自 ./node_modules/mini-css-extract-plugin/dist/loader.js): ModuleBuildError:模块构建失败(来自 ./node_modules/postcss-loader/dist/cjs.js): 错误:找不到 'bootstrap/dist/css/bootstrap.min.css'

解决方法: 运行 下面的命令用于安装额外的包

npm install bootstrap jquery popper.js