快应用TypeError: The ‘compilation‘ argument must be an instance of Compilation错误

完整日志:

d:\QuickAppProjects\quickapp-component\node_modules\fa-toolkit\node_modules\webpack\lib\NormalModule.js:227 throw new TypeError( ^ TypeError: The 'compilation' argument must be an instance of Compilation at NormalModule.getCompilationHooks (d:\QuickAppProjects\quickapp-component\node_modules\fa-toolkit\node_modules\webpack\lib\NormalModule.js:227:10) at d:\QuickAppProjects\quickapp-component\node_modules\fa-toolkit\node_modules\webpack\lib\LoaderOptionsPlugin.js:46:17

原因:

这个问题大多数情况下是由于 Webpack 版本不匹配 导致的。

如何验证:

在项目根目录运行以下命令,看看有哪些版本:

npx webpack -v

npm ls webpack

如果结果里有多个版本,比如:

my-project@1.0.0

├── webpack@5.91.0

└─┬ fa-toolkit@1.2.3

└── webpack@4.46.0

那就确定是版本冲突引起的。

解决办法:

强制 fa-toolkit 使用项目根目录的 webpack 实例,我们可以用 npm 的「依赖去重」机制来让所有依赖共享同一个 webpack。

1.执行以下命令:

删除旧模块

rm -rf node_modules package-lock.json

重新安装依赖并去重

npm install

npm dedupe

2.然后再执行:

npm ls webpack

3.理想输出应该变成:

│ ├─┬ babel-loader@8.2.5

│ │ └── webpack@5.76.2 deduped

│ ├─┬ stylus-loader@7.0.0

│ │ └── webpack@5.76.2 deduped

│ ├─┬ webpack-cli@5.0.2

│ │ ├─┬ @webpack-cli/configtest@2.1.1

│ │ │ └── webpack@5.76.2 deduped

│ │ ├─┬ @webpack-cli/info@2.0.2

│ │ │ └── webpack@5.76.2 deduped

│ │ ├─┬ @webpack-cli/serve@2.0.5

│ │ │ └── webpack@5.76.2 deduped

│ │ └── webpack@5.76.2 deduped

│ └─┬ webpack@5.76.2

│ └─┬ terser-webpack-plugin@5.3.14

│ └── webpack@5.76.2 deduped

└─┬ less-loader@10.2.0

└── webpack@5.76.2 deduped

webpack版本都一样了。

补充 fa-toolkit 是什么

fa-toolkit 一般会集成一系列 webpack 插件和工具,用来完成快应用的构建流程,例如:

功能模块 说明
🔧 webpack 配置生成 自动生成适配快应用项目结构的 webpack 配置(入口、输出、loader等)
📦 打包优化 压缩、去注释、资源合并、生成 .rpk.hap
📜 资源编译 编译 .ux / .qxml / .css / .js 等文件为快应用识别格式
🧩 组件打包 当你写一个"快应用组件库"(比如广告组件)时,它帮助你打包成 npm 模块或独立组件
🧠 开发时热更新 监听源码变动并自动构建(类似 webpack-dev-server 的行为)
相关推荐
心.c1 小时前
Vue3+Node.js实现文件上传分片上传和断点续传【详细教程】
前端·javascript·vue.js·算法·node.js·哈希算法
roamingcode2 小时前
我是如何 Vibe Coding,将 AI CLI 工具从 Node.js 迁移到 Rust 并成功发布的
人工智能·rust·node.js·github·claude·github copilot
冬奇Lab1 天前
一天一个开源项目(第8篇):UI/UX Pro Max Skill - AI设计智能助手,让AI帮你构建专业UI/UX
ui·开源·ux
学嵌入式的小杨同学1 天前
【Linux 封神之路】文件操作 + 时间编程实战:从缓冲区到时间格式化全解析
linux·c语言·开发语言·前端·数据库·算法·ux
Stream_Silver2 天前
【Node.js 安装报错解决方案:解决“A later version of Node.js is already installed”问题】
node.js
Anthony_2312 天前
基于 Vue3 + Node.js 的实时可视化监控系统实现
node.js
27669582922 天前
美团 小程序 mtgsig
python·小程序·node·js·mtgsig1.2·美团小程序·大众点评小程序
说给风听.2 天前
解决 Node.js 版本冲突:Windows 系统 nvm 安装与使用全指南
windows·node.js
森叶2 天前
Node.js 跨进程通信(IPC)深度进阶:从“杀人”的 kill 到真正的信号
node.js·编辑器·vim
学嵌入式的小杨同学3 天前
【Linux 实战】Makefile 自动化构建进阶:静态库 / 动态库通用模板(一键编译 + 系统安装)
linux·开发语言·git·vscode·spring·vim·ux