webpack4升级指北

本文介绍了webpack4升级的相关内容。安装方面,需重新安装webpack4、webpack-cli等依赖包,处理html-webpack-plugin报错及loader升级问题。配置上,新增mode配置,不同环境有不同默认配置;去除CommonsChunkPlugin,用optimization.splitChunks划分模块;无需UglifyJsPlugin,用optimization.minimize。

原文链接:http://www.imooc.com/article/23555

安装

首先你要重新安装以下的依赖包:

  1. webpack4
  2. webpack-cli(用来启动webpack)
  3. html-webpack-plugin还没有更新,会出现compilation.templatesPlugin is not a function的错误,目前需要npm i webpack-contrib/html-webpack-plugin -D安装,官方说法是因为作者这段时间没空更新,所以他们自己fork了一份改了,现在先用这种方式用着,等作者有空了再合并进去。
  4. 其他各种配件升级,dev-server升级到3,各种loader你们自己看着办,如果是新装的应该是已经支持了的,如果在编译过程中报can not find xxx的错误,说明xxx对应的loader可能需要升级了,因为webpack4去掉了this.options的支持.
  5. 看一下有没有peerDependencies的提醒,有的话升级以下插件。目前来说我剩下一个ajv-keywords@3.1.0
    requires a peer of ajv@^6.0.0 but none is installed. You must install peer dependencies yourself.的莫名其妙提醒,暂时没什么影响,也没查到解决方法,所以先放着,你们如果重新安装包可能就没这个错了。

以上这些就是安装包的工作,基本就差不多了。

配置
mode

webpack加了一个mode配置,只有两个值development | production,对不同的环境他会提供不同的一些默认配置,比如开发环境下面默认启用optimization.namedModules(原NamedModulesPlugin,现已弃用),而生产环境默认使用optimization.noEmitOnErrors(原NoEmitOnErrorsPlugin,现已弃用)。

不同模式下的默认配置如下:

  1. 生产环境默认开启了很多代码优化(minify,splite等)
  2. 开发时开启注视和验证,并且自动加上了eval devtool
  3. 生产环境不支持watching,开发环境优化了重新打包的速度
  4. 生产环境开启模块串联(原ModuleConcatenationPlugin),没用过不多说
  5. 自动设置process.env.NODE_ENV到不同环境,也就是不需要DefinePlugin来做这个了
  6. 如果你给mode设置为none,所有默认配置都去掉了

如果不加这个配置webpack会出现提醒,所以还是加上吧

CommonsChunkPlugin

相信大家如果听说过webpack4的更新,最大的感触应该就是去除了CommonsChunkPlugin,毕竟官方change log写的篇幅最多的就是这个

CommonsChunkPlugin删除之后,改成使用optimization.splitChunks进行模块划分,详细文档看这里

官方的说法是默认设置已经对大部分用户来说非常棒了,但是需要注意一个问题,默认配置只会对异步请求的模块进行提取拆分,如果要对entry进行拆分,需要设置optimization.splitChunks.chunks = ‘all’。其他的内容大家就自己研究吧。

对应之前我们拆分runtime的情况,现在也有一个配置optimization.runtimeChunk,设置为true就会自动拆分runtime文件

UglifyJsPlugin

现在也不需要使用这个plugin了,只需要使用optimization.minimize为true就行,production mode下面自动为true

optimization.minimizer可以配置你自己的压缩程序

其他

还有很多是我们平时使用不太到的升级,更多的是一些性能上的优化和功能上的升级,附上官方change log,希望官方文档赶紧出来吧。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值