【工程化】前端打包时间优化

背景

在打包编译时发现built时间长达57s,并且提示超过500kb,说明需要优化了!

优化

插件推荐: Rollup Plugin Visualizer
项目引入:

javascript 复制代码
import { visualizer } from 'rollup-plugin-visualizer'

export default defineConfig(() => {

    return {
        build: {
            sourcemap: true
        },
        plugins: [
            vue(),
            visualizer({
                open: true, // 构建完成后会自动打开浏览器,显示可视化报告。
                filename: 'stats.html', // 生成的报告文件名称
                gzipSize: true, // 显示各文件在经过 gzip 压缩后的大小
                brotliSize: true // 显示各文件在经过 brotli 压缩后的大小
            }),
       ]
   }
}

页面展示

可以看到占主要大头的是最右侧两块,可以去除全局引用+build.rollupOptions.output.manualChunks手动分包

初步优化一波,把最大的vxxxx部分和ant-design-vue拆出来

javascript 复制代码
export default defineConfig(({ mode }) => {

    return {
        build: {
            sourcemap: true,
            rollupOptions: {
                output: {
                    manualChunks(id) {
                        if (id.includes('@visactor')) {
                            if (id.includes('vchart'))
                                return 'vendor-visactor-chart'
                            if (id.includes('vtable'))
                                return 'vendor-visactor-table'
                            if (id.includes('vlayout'))
                                return 'vendor-visactor-layout'
                            return 'vendor-visactor-other'
                        }
                        if (id.includes('ant-design-vue')) {
                            // 将大型组件单独分包
                            if (id.includes('/table/')) return 'antd-table'
                            if (id.includes('/form/')) return 'antd-form'
                            if (id.includes('/date-picker/')) return 'antd-date'
                            if (id.includes('/select/')) return 'antd-select'
                            if (id.includes('/modal/')) return 'antd-modal'
                            // 样式和工具单独分包
                            if (id.includes('/style/')) return 'antd-style'
                            if (id.includes('/_util/')) return 'antd-util'
                            return 'antd-other'
                        }
                    }
                }
            }
        },
        plugins: [.....]

就有一些效果了(15%左右),再继续细化即可~

相关推荐
掘金安东尼1 分钟前
从平面到空间:用 React Three Fiber 构建 3D 产品网格
前端·javascript·面试
小时前端1 分钟前
HTTPS 页面加载 HTTP 脚本被拦?同源代理来救场
前端·https
用户683709359552 分钟前
在 Rokid AR 眼镜里玩消消乐:基于 Unity 2022 LTS + UXR 3.0 SDK 的轻量级 AR 游戏尝试
前端
zzjyr3 分钟前
@umijs/max 中导出的 request 方法,如何实现 GET/POST/PUT/DELETE 这四种核心请求
前端
swipe3 分钟前
#用这 9 个浏览器 API,我把页面从“卡成 PPT”救回到 90+(每个都有能直接抄的例子)
前端·javascript·面试
zzjyr5 分钟前
基于 @umijs/max 的 request 补充常见错误统一处理、请求取消、重复请求防抖的完整方案
前端
拖拉斯旋风17 分钟前
深入浅出 RAG:从网页爬取到智能问答的完整链路解析
前端
Mintopia31 分钟前
Vite 发展现状与回顾:从“极致开发体验”到生态基础设施
前端
前端双越老师1 小时前
前端面试常见的 10 个场景题
前端·面试·求职
孟祥_成都2 小时前
【全网最通俗!新手到AI全栈开发必读】 AI 是如何进化到大模型的
前端·人工智能·全栈