vue項目開啟gzip壓縮功能簡單實例
前言:為了優(yōu)化首屏加載速度,啟用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搭建的服務(wù)器,因此只記錄用node使用的情況。
1.將dist文件放放在含有nodejs后臺的文件夾下
2.修改server.js文件
const path = require('path'); const fs = require('fs'); //導(dǎo)入express模塊 const express = require('express') //創(chuàng)建express的服務(wù)器實例 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編碼格式來解析,并把對應(yīng)的“.gz”格式文件發(fā)送給瀏覽器。 response.setHeader('Content-Encoding', 'gzip') response.sendFile(fullPath); } else { next() } }) //將dist目錄托管為靜態(tài)資源服務(wù)器 app.use(express.static('./dist')) //調(diào)用app.listen方法,指定端口號并啟動web服務(wù)器 app.listen(3140,function(){ console.log('Express server running at http://127.0.0.1:3140'); })
3.over
可以看到,導(dǎo)致首屏加載過慢的罪魁禍首已經(jīng)壓縮成功啦
總結(jié)
到此這篇關(guān)于vue項目開啟gzip壓縮功能的文章就介紹到這了,更多相關(guān)vue開啟gzip壓縮內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue3中使用keepAlive緩存路由組件不生效的問題解決
這篇文章主要介紹了vue3中使用keepAlive緩存路由組件不生效的問題解決,本文給大家介紹的非常詳細,對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2024-06-06vue使用echarts實現(xiàn)中國地圖和點擊省份進行查看功能
這篇文章主要介紹了vue使用echarts實現(xiàn)中國地圖和點擊省份進行查看功能,本文通過實例代碼給大家詳細講解,對vue echarts 中國地圖相關(guān)知識感興趣的朋友一起看看吧2022-12-12在vue中使用inheritAttrs實現(xiàn)組件的擴展性介紹
這篇文章主要介紹了在vue中使用inheritAttrs實現(xiàn)組件的擴展性介紹,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12vue+element實現(xiàn)頁面頂部tag思路詳解
這篇文章主要介紹了vue+element實現(xiàn)頁面頂部tag效果,頁面顯示由數(shù)組循環(huán)得出,數(shù)組可存儲在store里,tags數(shù)組里面已經(jīng)有值,由于默認是白色,所以頁面上看不出,接下來就是給選中的標簽高亮,需要的朋友可以參考下2021-12-12iview-table組件嵌套input?select數(shù)據(jù)無法雙向綁定解決
這篇文章主要為大家介紹了iview-table組件嵌套input?select數(shù)據(jù)無法雙向綁定解決示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09