您现在的位置是:首页 > 伤感句子

vite打包优化vite-plugin-compression的使用

作者:胡椒时间:2024-03-24 17:10:58分类:伤感句子

简介  文章浏览阅读9.5k次。当前端资源过大时,服务器请求资源会比较慢。前端可以将资源通过Gzip压缩使文件体积减少大概60%左右,压缩后的文件,通过后端简单处理,浏览器可以将其正常解析出来。如果浏览器的请求头中包含。_vite-plugin-compression

点击全文阅读

什么是gzip 压缩

当前端资源过大时,服务器请求资源会比较慢。前端可以将资源通过Gzip压缩使文件体积减少大概60%左右,压缩后的文件,通过后端简单处理,浏览器可以将其正常解析出来。

如果浏览器的请求头中包含c ontent-encoding: gzip,即证明浏览器支持该属性。

gzip的使用

前端压缩

前端使用gzip压缩代码很容易,通过插件即可。

vue-cli中使用compression-webpack-plugin插件

const compressionWebpackPlugin = require("compression-webpack-plugin");module.exports = {  configureWebpack: {    plugins: [      // 开启gzip      new compressionWebpackPlugin({        filename: "[path][base].gz",        algorithm: "gzip",        test: /.js$|.css$|.html$/,        threshold: 10240, // 对超过10k的数据压缩        minRatio: 0.8 // 压缩率小于0.8才会压缩      }),]}

vite中使用vite-plugin-compression插件

import viteCompression from 'vite-plugin-compression'export default defineConfig({  plugins:[    viteCompression()  ]})

浏览器解析

压缩的代码放到服务器后,需要后端配置一些东西,浏览器才可以解析

1、Nginx服务器只需要配置:

2、nodejs启用gzip以express框架为例:

npm install compression npm install @types/compression --save-dev
import compression from 'compression';...const app = express();app.use(compression());...

compression-webpack-plugin

插件打包对比

我们着重介绍下改插件的使用。如果我们项目中不配置此插件,打包后的项目资源如下:


配置此插件后:

import { defineConfig } from 'viteimport viteCompression from 'vite-plugin-compression'export default defineConfig({  plugins:[    viteCompression()  ]})

通过打包结果,我们看出部分文件进行了gzip压缩。

配置项

可配置项名称数据类型默认值释义
verbosebooleantrue是否在控制台中输出压缩结果
filterRegExp or (file: string) => boolean/.(jsmjs
disablebooleanfalse是否禁用
thresholdnumber1025如果体积大于阈值,则进行压缩,单位为b
algorithmstringgzip压缩算法,可选[‘gzip’,‘brotliCompress’,‘deflate’,‘deflateRaw’]
extstring.gz生成的压缩包的后缀
compressionOptionsobject-对应压缩算法的参数
deleteOriginFileboolean-压缩后是否删除源文件

我们简单配置下试试

import { defineConfig } from 'viteimport viteCompression from 'vite-plugin-compression'export default defineConfig({  plugins:[    viteCompression(      {        algorithm: 'gzip',        threshold: 10240,        verbose: false,        deleteOriginFile: true      }    )  ]})

这个配置项,我们通过algorithm指定了压缩算法为gzip;通过threshold指定文件大于10240b(10kb)时才压缩文件;通过verbose禁止在控制台输出压缩结果;通过deleteOriginFile指定压缩完文件后删除源文件。

大家可以根据自己的需求配置。

点击全文阅读

郑重声明:

本站所有活动均为互联网所得,如有侵权请联系本站删除处理

我来说两句