webpack打包优化js大小

本文章仅提供解决问题的一个方向和遇到的坑更多具体的还需要自身不断去摸索.文章目录前言一、JS拆分二、按需加载tree shaking总结前言自己搭建了一个webpack+react+typescript打包的脚手架,使用antd来实现UI,build完后出现了一行WARNINGWARNING in entrypoint size limit: The following entrypoint(s) combined asset size exceeds the recommended limit
摘要由CSDN通过智能技术生成

本文章仅提供解决问题的一个方向和遇到的坑更多具体的还需要自身不断去摸索.


前言

自己搭建了一个webpack+react+typescript打包的脚手架,使用antd来实现UI,build完后出现了一行WARNING

WARNING in entrypoint size limit: The following entrypoint(s) combined asset size exceeds the recommended limit (244 KiB). This can impact web performance.
Entrypoints:
  index (4.55 MiB)
      index.js

就是一个特别简单的页面打完包之后竟然有4.55M这么大,于是就想着做一些优化。


以下是优化的调整

一、JS拆分

首先想到的肯定是去官方文档上找一找解决方案。
官方描述文档上首先说到的是minimize,因为之前已经配置过UglifyJsPlugin所以这一块就不用再做配置了,但是在后续打包过程中发现UglifyJsPlugin不支持ES6所以替换为TerserPlugin。
再往下看文档就是splitChunks和runtimeChunk这个就是我们需要的了,在此之前可能需要先了解Chunk、module和bundle等概念这里就不展开描述了。在webpack.config加入对应的配置(此处只做了简单配置,SplitChunksPlugin还得提供了很多丰富的配置来达到我们想要的效果,详细的配置信息及使用方法请参照官方文档),然后build看一下具体的效果.

optimization:{
   
        splitChunks: {
   
            chunks: 'all',
            name: false,
        },
        runtimeChunk: {
   
            name: entrypoint => `runtime-${
     entrypoint.name}`,
        }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值