这两个版本完全不匹配,这正是导致你项目报错的根本原因。
简单来说,Webpack 4 是一个较旧的版本,而 webpack-cli 7 是专门为 Webpack 5 设计的最新版本。它们之间存在巨大的代沟,无法协同工作。
❌ 为什么不匹配?
- Webpack 4 需要配合 webpack-cli 3.x 版本使用。
- webpack-cli 7.x 是配合 Webpack 5 使用的,它的内部架构和命令处理方式与 Webpack 4 完全不同。
当你使用 Webpack 4 搭配 webpack-cli 7 时,CLI 工具无法正确识别和启动旧版的 Webpack 核心,从而导致类似 Cannot find module 或 TypeError 的报错。
✅ 解决方案
既然你正在将 @vue/cli 降级到 4.5.15(它默认使用 Webpack 4),你需要将项目本地的 webpack 和 webpack-cli 版本也调整到兼容的组合。
建议修改你的 package.json 文件,将这两个依赖的版本修改为以下兼容组合:
"devDependencies": {
"webpack": "^4.47.0",
"webpack-cli": "^3.3.12"
}
注意 :
^4.5.15这个版本号通常指的是@vue/cli的版本,Webpack 4 的常见稳定版本是4.4x.x。
🛠️ 操作步骤
- 修改
package.json:按照上面的代码块,将webpack和webpack-cli的版本号改对。 - 清理依赖 :删除项目中的
node_modules文件夹和package-lock.json文件。 - 重新安装 :在命令行运行
npm install。
完成这些步骤后,你的 Webpack 4 环境就能正常启动了。