vite + vue3项目 对vite.config.ts 配置gzip压缩

对vite + vue3 创建的项目打包的时候进行 gzip 压缩

    1. 安装 vite-plugin-compression 插件
npm install vite-plugin-compression
    1. 在 vite.config.ts/js 中导入vite-plugin-compression插件
import viteCompression from 'vite-plugin-compression'
    1. 在 vite.config.ts/js 中的 plugins 中使用vite-plugin-compression插件即可
export default defineConfig({
	plugins: [
		viteCompression({
	      filter: /\.(js|css|json|txt|html|ico|svg)(\?.*)?$/i, // 需要压缩的文件
	      threshold: 1024, // 文件容量大于这个值进行压缩
	      algorithm: 'gzip', // 压缩方式
	      ext: 'gz', // 后缀名
	      deleteOriginFile: true, // 压缩后是否删除压缩源文件
    	})
	]
})
    1. 保存改变后进行打包, 文件体积明显减小 3 倍左右
      在这里插入图片描述
为了优化vite项目的打包体积,可以在vite.config.ts文件中进行配置。以下是一些常用的配置选项: 1. 使用rollup-plugin-terser插件进行代码压缩,可以将代码体积进一步减小。 2. 使用vite-plugin-compression插件进行gzip压缩,可以进一步减小文件体积。 3. 使用splitChunks选项将公共代码提取出来,避免重复打包。 4. 使用tree shaking技术,只打包项目中实际使用到的代码,避免打包无用代码。 5. 使用webpack-bundle-analyzer插件分析打包后的文件,找出体积较大的文件并进行优化。 6. 配置alias选项,将一些常用的路径映射为别名,避免重复打包。 7. 配置externals选项,将一些不需要打包的依赖项排除在外,减小打包体积。 8. 配置cacheDir选项,将缓存目录设置为项目外部,避免重复打包。 以下是一个示例的vite.config.ts文件,其中包含了上述的一些优化配置: ``` import { defineConfig } from 'vite'; import vue from '@vitejs/plugin-vue'; import { terser } from 'rollup-plugin-terser';import viteCompression from 'vite-plugin-compression'; export default defineConfig({ plugins: [ vue(), terser(), viteCompression({ verbose: true, disable: false, threshold: 10240, algorithm: 'gzip', ext: '.gz', }), ], build: { target: 'es2015', outDir: 'dist', assetsDir: 'assets', sourcemap: false, rollupOptions: { output: { manualChunks: { vue: ['vue'], antd: ['ant-design-vue'], }, }, }, }, resolve: { alias: { '@': '/src', }, }, optimizeDeps: { include: ['axios'], exclude: ['vue-demi'], }, server: { port: 3000, proxy: { '/api': { target: 'http://localhost:8080', changeOrigin: true, rewrite: (path) => path.replace(/^\/api/, ''), }, }, }, }); ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值