Vue項目打包后js文件壓縮

前言

這段時間因為免費試用了https://free.aliyun.com/一臺阿里云的服務(wù)器城须,配置是 2核4G 2M,
因為帶寬太低了米苹,每次在第一次加載的時候太慢了糕伐,通過F12調(diào)試,發(fā)現(xiàn)主要是因為加載的 js 過大而引起的蘸嘶。因此本文將主要講解Vue項目打包后js良瞧、css、svg等文件過大的解決辦法训唱。

image

引入插件 compression-webpack-plugin

通過引入 compression-webpack-plugin 插件來打包褥蚯,然后開啟 nginx gzip 來解決問題

CompressionWebpackPlugin插件參數(shù)配置:官網(wǎng) https://www.webpackjs.com/plugins/compression-webpack-plugin/

  • 安裝插件依賴
#指定版本
npm i compression-webpack-plugin@5.0.1
#或者
npm i -D compression-webpack-plugin
npm install compression-webpack-plugin --save
image
  • 說明

    • i 是install 的簡寫
    • -S就是--save的簡寫
    • -D就是--save-dev 這樣安裝的包的名稱及版本號就會存在package.json的devDependencies這個里面,而--save會將包的名稱及版本號放在dependencies里面况增。
  • 修改 vue.config.js 文件赞庶,內(nèi)容如下

const CompressionPlugin = require('compression-webpack-plugin');
const productionGzipExtensions = /\.(js|css|json|txt|html|ico|svg)(\?.*)?$/i;
module.exports = {
  publicPath: '/',
  productionSourceMap: false,
  configureWebpack: {...},
  chainWebpack: config => {
    config.resolve.alias.set('@', resolve('src'));
    config.when(process.env.NODE_ENV !== 'development',
        config => {
          // 提供帶 Content-Encoding 編碼的壓縮版的資源
          config.plugin('compressionPlugin')
            .use(new CompressionPlugin({
              filename: '[path].gz[query]', // 目標文件名
              algorithm: 'gzip',  // 壓縮算法
              test: productionGzipExtensions, // 滿足正則表達式的文件會被壓縮
              threshold: 10240, // 只處理比這個值大的資源。按字節(jié)計算 10240=10KB
              minRatio: 0.8, // 只有壓縮率比這個值小的資源才會被處理
              deleteOriginalAssets: true // 是否刪除原資源
            }));
        }
      )
  }
}

更多詳細配置請查看本項目代碼澳骤,地址:https://gitee.com/zmzhou-star/easyboot.git

Vue項目打包

npm run build:prod

配置 compression-webpack-plugin 前后打包對比歧强,我們查看 dist目錄,能夠發(fā)現(xiàn)大于10KB的 js为肮,css 等文件已經(jīng)被壓縮了

配置 compression-webpack-plugin

image

配置 compression-webpack-plugin

image

修改Nginx配置 開啟 gzip

# on為啟用摊册,off為關(guān)閉
gzip on;
# Nginx的動態(tài)壓縮是對每個請求先壓縮再輸出,這樣造成虛擬機浪費了很多cpu颊艳,解決這個問題可以利用nginx模塊Gzip Precompression茅特,這個模塊的作用是對于需要壓縮的文件,直接讀取已經(jīng)壓縮好的文件(文件名為加.gz)棋枕,而不是動態(tài)壓縮白修,對于不支持gzip的請求則讀取原文件
gzip_static on;
# 設(shè)置允許壓縮的頁面最小字節(jié)數(shù),頁面字節(jié)數(shù)從header頭中的Content-Length中進行獲取戒悠。默認值是0熬荆,不管頁面多大都壓縮舟山。建議設(shè)置成大于1k的字節(jié)數(shù)绸狐,小于1k可能會越壓越大卤恳。
gzip_min_length 1k;
# 獲取多少內(nèi)存用于緩存壓縮結(jié)果,‘4 16k’表示以16k*4為單位獲得
gzip_buffers 16 64K;
# 識別http協(xié)議的版本,早期瀏覽器可能不支持gzip自解壓,用戶會看到亂碼
gzip_http_version 1.1;
# gzip壓縮比(1~9)寒矿,越小壓縮效果越差突琳,但是越大處理越慢,所以一般取中間值;
gzip_comp_level 5;
# 對特定的MIME類型生效,其中'text/html’被系統(tǒng)強制啟用
gzip_types text/plain application/x-javascript text/css application/xml application/javascript;
# 啟用應(yīng)答頭"Vary: Accept-Encoding"
gzip_vary on;
# IE5.5和IE6 SP1使用msie6參數(shù)來禁止gzip壓縮 )指定哪些不需要gzip壓縮的瀏覽器(將和User-Agents進行匹配),依賴于PCRE庫
gzip_disable "MSIE [1-6].";

完整Nginx配置請看 Nginx安裝

  • 重啟 nginx
systemctl reload nginx

測試效果符相,訪問:http://47.119.196.11拆融,F(xiàn)12打開開發(fā)者工具

壓縮前

image

壓縮后,發(fā)現(xiàn)響應(yīng)時間得到了明顯提升

image
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末啊终,一起剝皮案震驚了整個濱河市镜豹,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌蓝牲,老刑警劉巖成肘,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件启泣,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機单鹿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來腰根,“玉大人扯夭,你說我怎么就攤上這事∶吻溃” “怎么了般贼?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長奥吩。 經(jīng)常有香客問我具伍,道長,這世上最難降的妖魔是什么圈驼? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任人芽,我火速辦了婚禮,結(jié)果婚禮上绩脆,老公的妹妹穿的比我還像新娘萤厅。我一直安慰自己,他們只是感情好靴迫,可當(dāng)我...
    茶點故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布惕味。 她就那樣靜靜地躺著,像睡著了一般玉锌。 火紅的嫁衣襯著肌膚如雪名挥。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天主守,我揣著相機與錄音禀倔,去河邊找鬼榄融。 笑死,一個胖子當(dāng)著我的面吹牛救湖,可吹牛的內(nèi)容都是我干的愧杯。 我是一名探鬼主播,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼鞋既,長吁一口氣:“原來是場噩夢啊……” “哼力九!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起邑闺,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤跌前,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后陡舅,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體舒萎,經(jīng)...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年蹭沛,在試婚紗的時候發(fā)現(xiàn)自己被綠了臂寝。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,779評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡摊灭,死狀恐怖咆贬,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情帚呼,我是刑警寧澤掏缎,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站煤杀,受9級特大地震影響眷蜈,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜沈自,卻給世界環(huán)境...
    茶點故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一酌儒、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧枯途,春花似錦忌怎、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至晚岭,卻和暖如春鸥印,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工库说, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留狂鞋,地道東北人。 一個月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓璃弄,卻偏偏與公主長得像要销,于是被迫代替她去往敵國和親构回。 傳聞我的和親對象是個殘疾皇子夏块,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,700評論 2 354

推薦閱讀更多精彩內(nèi)容