vue项目开启gzip压缩功能简单实例
更新时间:2023年07月24日 11:29:44 作者:阿吧阿巴阿巴
这篇文章主要给大家介绍了关于vue项目开启gzip压缩功能的相关资料,gizp压缩是一种http请求优化方式,通过减少文件体积来提高加载速度,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
前言:为了优化首屏加载速度,启用gzip压缩。
一、安装compression-webpack-plugin
//新版本不太兼容,推荐这个版本 npm install compression-webpack-plugin@6.1.1 --save-dev
二、修改vue.config.js文件
// 1.先引入 const CompressionWebpackPlugin = require('compression-webpack-plugin'); // 2.在configureWebpack下面进行配置(基本配置) plugins: [ new CompressionWebpackPlugin({ // [file] 会被替换成原始资源。[path] 会被替换成原始资源的路径,[query] 会被替换成查询字符串 filename: '[path][base].gz', // 压缩成gzip algorithm: 'gzip', // 使用正则给匹配到的文件做压缩,这里是给html、css、js以及字体做压缩 test: /\.js$|\.css$|\.html$|\.ttf$|\.eot$|\.woff$/, // 只有大小大于该值的资源会被处理。单位是 bytes。默认值是 0。 threshold: 10240, // 只有压缩率小于这个值的资源才会被处理。默认值是 0.8。 minRatio: 0.8 }) ] // 3.然后 yarn build 进行打包得到dist文件夹,就可以看到生成了很多gzip后缀的文件
三、在nodejs中使用
由于我是用nodejs搭建的服务器,因此只记录用node使用的情况。
1.将dist文件放放在含有nodejs后台的文件夹下
2.修改server.js文件
const path = require('path'); const fs = require('fs'); //导入express模块 const express = require('express') //创建express的服务器实例 const app = express() app.use((request, response, next) => { //由于我是把server.js和dist文件夹放在同一路径下,因此需要拼接 const fullPath = path.join(__dirname,'dist',`${request.originalUrl}.gz`); // 检测是否存在同名.gz压缩文件 if (fs.existsSync(fullPath)) { // 存在就告诉浏览器用gzip编码格式来解析,并把对应的“.gz”格式文件发送给浏览器。 response.setHeader('Content-Encoding', 'gzip') response.sendFile(fullPath); } else { next() } }) //将dist目录托管为静态资源服务器 app.use(express.static('./dist')) //调用app.listen方法,指定端口号并启动web服务器 app.listen(3140,function(){ console.log('Express server running at http://127.0.0.1:3140'); })
3.over
可以看到,导致首屏加载过慢的罪魁祸首已经压缩成功啦
总结
到此这篇关于vue项目开启gzip压缩功能的文章就介绍到这了,更多相关vue开启gzip压缩内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
vue-cli3.0修改打包后的文件名和文件地址,打包后本地运行报错解决
这篇文章主要介绍了vue-cli3.0修改打包后的文件名和文件地址,打包后本地运行报错的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-04-04
最新评论