记一次webpack2升级为webpack4的爬坑之路

2024-04-25 17:48

本文主要是介绍记一次webpack2升级为webpack4的爬坑之路,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        webpack4官方发布以来,很多博主都已经上手开撸了,但是大体都是对着API新配置一份,我今天尝试了一下将我们公司的webpack2项目迁移到webpack4,下面是记录的几个坑。

一、环境准备

    1、node 6.10+

    2、下载webpack4  

 npm install webpack@4 -D

二、根据控制台错误一个一个的修改

问题1、

WebpackOptionsValidationError: Invalid configuration object. Webpack has been initialised using a configuration object that does not match the API schema.- configuration.module has an unknown property 'loaders'. These properties are valid:

解决1:将webpack.conf.js中的 loaders 改成 rules 。(ps有多少改多少!)


问题2、TypeError: compilation.mainTemplate.applyPluginsWaterfall is not a function

解决2:网上有很多说是下载 webpack-contrib/html-webpack-plugin 这个官方临时插件解决,但是当我去下的时候发现已经下不了了,很遗憾!

过去的解决办法npm install webpack-contrib/html-webpack-plugin -D

不过现在有了正式版

现在的解决办法npm install html-webpack-plugin@3.2.0 -D


问题3、Cannot read property 'babel' of undefined

解决3:

npm install babel-loader@7 -D


问题4、Cannot read property 'vue' of undefined 

解决4:

npm install vue-loader@14 -D


问题5、Module build failed (from ./node_modules/css-loader/index.js)

解决5:style-loader和css-loader书写位置不能错,并跟新url-loader@1+file-loader@1

{test: /\.css$/, use: ['style-loader','css-loader']},
npm install url-loader@1 -D
npm install file-loader@1 -D

这5个问题弄完之后,项目就可以成功跑起来了,然后需要什么配置再自己看文档添加即可,最后附上我的package.json供大家参考

{"name": "","version": "1.0.0","description": "Resource Sharing Platform","author": "","private": true,"scripts": {"dev": "node build/dev-server.js","start": "node build/dev-server.js","build": "node build/build.js"},"dependencies": {"jquery": "^3.2.1","vue": "^2.2.6","vue-router": "^2.3.1","webpack": "^4.12.0"},"devDependencies": {"autoprefixer": "^6.4.0","babel-core": "^6.0.0","babel-loader": "^7.1.4","babel-plugin-transform-runtime": "^6.0.0","babel-preset-es2015": "^6.0.0","babel-preset-stage-2": "^6.0.0","babel-register": "^6.0.0","clean-webpack-plugin": "^0.1.13","connect-history-api-fallback": "^1.1.0","css-loader": "^0.28.11","eventsource-polyfill": "^0.9.6","express": "^4.13.3","extract-text-webpack-plugin": "^2.0.0","file-loader": "^1.1.11","function-bind": "^1.0.2","glob": "^7.1.1","html-webpack-plugin": "^3.2.0","http-proxy-middleware": "^0.17.2","json-loader": "^0.5.4","opn": "^4.0.2","ora": "^0.3.0","shelljs": "^0.7.4","style-loader": "^0.21.0","url-loader": "^1.0.1","vue-loader": "^15.2.4","vue-resource": "^1.3.1","vue-style-loader": "^4.1.0","vue-template-compiler": "^2.5.16","webpack-cli": "^3.0.6","webpack-dev-middleware": "^1.8.3","webpack-hot-middleware": "^2.12.2","webpack-merge": "^4.1.0"}
}


这篇关于记一次webpack2升级为webpack4的爬坑之路的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/935376

相关文章

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

Ubuntu如何升级Python版本

《Ubuntu如何升级Python版本》Ubuntu22.04Docker中,安装Python3.11后,使用update-alternatives设置为默认版本,最后用python3-V验证... 目China编程录问题描述前提环境解决方法总结问题描述Ubuntu22.04系统自带python3.10,想升级

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

Linux升级或者切换python版本实现方式

《Linux升级或者切换python版本实现方式》本文介绍在Ubuntu/Debian系统升级Python至3.11或更高版本的方法,通过查看版本列表并选择新版本进行全局修改,需注意自动与手动模式的选... 目录升级系统python版本 (适用于全局修改)对于Ubuntu/Debian系统安装后,验证Pyt

MySQL 升级到8.4版本的完整流程及操作方法

《MySQL升级到8.4版本的完整流程及操作方法》本文详细说明了MySQL升级至8.4的完整流程,涵盖升级前准备(备份、兼容性检查)、支持路径(原地、逻辑导出、复制)、关键变更(空间索引、保留关键字... 目录一、升级前准备 (3.1 Before You Begin)二、升级路径 (3.2 Upgrade

Nginx进行平滑升级的实战指南(不中断服务版本更新)

《Nginx进行平滑升级的实战指南(不中断服务版本更新)》Nginx的平滑升级(也称为热升级)是一种在不停止服务的情况下更新Nginx版本或添加模块的方法,这种升级方式确保了服务的高可用性,避免了因升... 目录一.下载并编译新版Nginx1.下载解压2.编译二.替换可执行文件,并平滑升级1.替换可执行文件

升级至三频BE12000! 华硕ROG魔盒Pro路由器首发拆解评测

《升级至三频BE12000!华硕ROG魔盒Pro路由器首发拆解评测》华硕前两天推出新一代电竞无线路由器——ROG魔盒Pro(StrixGR7Pro),该产品在无线规格、硬件配置及功能设计上实现全... 作为路由器行业的T1梯队厂商,华硕近期发布了新旗舰华硕ROG魔盒Pro,除了保留DIY属性以外,高达120

Python包管理工具pip的升级指南

《Python包管理工具pip的升级指南》本文全面探讨Python包管理工具pip的升级策略,从基础升级方法到高级技巧,涵盖不同操作系统环境下的最佳实践,我们将深入分析pip的工作原理,介绍多种升级方... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中