说可以通过配置build.rollupOptions.output.manualChunks来提升一下,好可以,我来配置一下,把那些可能大的包单独分配一下:

 1    build: {
 2        rollupOptions: {
 3            output: {
 4                manualChunks: {
 5                    codemirror: ['codemirror'],
 6                    pinia: ['pinia'],
 7                    router: ['vue-router'],
 8                    // 将 vue 相关的模块打包到单独的 chunk
 9                    vue: ['vue'],
10                    element: ['element-plus'],
11                    // 将大型库或组件单独打包
12                    largeLibrary: ['axios'],
13                },
14            },
15        },
16    },

然后再看一下,是变小了,但是还是500警告啊:

那就开始分析是哪个包比较大吧,使用rollup-plugin-visualizer这个插件来分析一下,rollup-plugin-visualizer是一个开源项目,地址:github.com/btd/rollup-…

安装:

 1npm install vite-plugin-compression --save-dev

配置插件

在 vite.config.js 文件中添加 rollup-plugin-visualizer 插件的配置,如下:

 1import { defineConfig } from 'vite'
 2import vue from '@vitejs/plugin-vue'
 3import { visualizer } from 'rollup-plugin-visualizer'
 4import path from 'path'
 5
 6const host = process.env.TAURI_DEV_HOST
 7
 8
 9export default defineConfig(async () => ({
10    plugins: [
11        vue(),
12        visualizer({
13            open: true, 
14            filename: 'stats.html', 
15            gzipSize: true, 
16            brotliSize: true, 
17        }),
18    ],
19    
20    
21    
22    clearScreen: false,
23    
24    server: {
25        port: 1420,
26        strictPort: true,
27        host: host || false,
28        hmr: host
29            ? {
30                  protocol: 'ws',
31                  host,
32                  port: 1421,
33              }
34            : undefined,
35        watch: {
36            
37            ignored: ['**/src-tauri/**'],
38        },
39    },
40    resolve: {
41        alias: {
42            '@': path.resolve(__dirname, 'src'),
43        },
44    },
45    build: {
46        rollupOptions: {
47            output: {
48                manualChunks: {
49                    codemirror: ['codemirror'],
50                    pinia: ['pinia'],
51                    router: ['vue-router'],
52                    
53                    vue: ['vue'],
54                    element: ['element-plus'],
55                    
56                    largeLibrary: ['axios'],
57                },
58            },
59        },
60    },
61}))

构建完成后,按照配置会自动生成报告 stats.html 文件。

如果配置为 open:true,则会在构建完成后自动打开报告页面:

 

如上图,打包文件占比较大的主要是以下 3 个包/文件:element-plus,edit,codemirror

所以,根据占比较大的文件去做针对性的优化即可。

对于elementui可以使用官方推荐的自动导入:快速开始 | Element Plus

配置完按需导入之后,就可以把main.ts里面的全量导入删除了:

然后再次打包就可以看到效果了

分析报告:

 

 

个人笔记记录 2021 ~ 2025