首頁 web前端 js教程 webpack專案的網路優化程式碼分享

webpack專案的網路優化程式碼分享

Feb 22, 2018 pm 01:32 PM
web webpack 程式碼

SPA應用的流程是:

  1. 載入HTML

  2. #載入javascript(bundle.js)

  3. 執行javascript,開始請求介面

  4. 先建立和介面的HTTP/HTTPS連線(dns查詢/tcp握手/TLS連結)

  5. #發送請求header,取得回應資料...

  6. 渲染數據,呈現給使用者

##我們用Vue/React + Webpack打包的js動輒300KB以上,步驟2會消耗一點時間。如果在

步驟2 進行中時,同步執行 步驟4 建立連接,就能節省一點點時間。 尤其在行動端,建立連線的時間佔了大頭,能省是省。

利用

<link rel="preconnect"> 讓瀏覽器預先建立連線。

主流瀏覽器大多已支援:https://caniuse.com/#feat=link-rel-preconnect

做了一個簡單的webpack插件: https://github.com /joaner/html-webpack-preconnect-plugin

// $ npm install html-webpack-preconnect-plugin --save-dev

var HtmlWebpackPreconnectPlugin = require('html-webpack-preconnect-plugin');

// webpack config
{
  ...
  plugins: [
    new HtmlWebpackPlugin({
      filename: 'index.html',

      // set the preconnect origins
      preconnect: [
        'http://api1.example.com',
        'http://api2.example.com',
      ]
    }),

    // enabled preconnect plugin
    new HtmlWebpackPreconnectPlugin(),
  ]
}
登入後複製
這個外掛程式做的事非常簡單,就是插入到

<head>裡:

&lt;!-- dist/index.html --&gt;
&lt;head&gt;
  ...
  &lt;link rel=&quot;preconnect&quot; href=&quot;http://api1.example.com&quot;&gt;
  &lt;link rel=&quot;preconnect&quot; href=&quot;http://api2.example.com&quot;&gt;
&lt;/head&gt;
登入後複製

#我之前用

HtmlWebpackPlugin的模板實現,但是略微有點繁瑣,所以提取成了插件。

&lt;!-- template.html --&gt;
&lt;link rel=&quot;preconnect&quot; href=&lt;%= htmlWebpackPlugin.options.api1_origin %&gt;&gt;
登入後複製
相關推薦:

詳解webpack模組及webpack3新功能

Webpack伺服器端程式碼打包實例詳解


################################################ #######webpack、vue、node實作單頁碼分享###############

以上是webpack專案的網路優化程式碼分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

兩個點博物館:邦格荒地地點指南
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

兩個點博物館:邦格荒地地點指南
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

藍色畫面代碼0x0000001怎麼辦 藍色畫面代碼0x0000001怎麼辦 Feb 23, 2024 am 08:09 AM

藍色畫面代碼0x0000001怎麼辦

解決win7驅動程式碼28的方法 解決win7驅動程式碼28的方法 Dec 30, 2023 pm 11:55 PM

解決win7驅動程式碼28的方法

電腦頻繁藍屏而且每次代碼不一樣 電腦頻繁藍屏而且每次代碼不一樣 Jan 06, 2024 pm 10:53 PM

電腦頻繁藍屏而且每次代碼不一樣

解決代碼0xc000007b錯誤 解決代碼0xc000007b錯誤 Feb 18, 2024 pm 07:34 PM

解決代碼0xc000007b錯誤

GE通用遠端程式碼可在任何裝置上編程 GE通用遠端程式碼可在任何裝置上編程 Mar 02, 2024 pm 01:58 PM

GE通用遠端程式碼可在任何裝置上編程

藍色畫面代碼0x000000d1代表什麼問題? 藍色畫面代碼0x000000d1代表什麼問題? Feb 18, 2024 pm 01:35 PM

藍色畫面代碼0x000000d1代表什麼問題?

詳解0x0000007f藍屏代碼的原因及解決方案 詳解0x0000007f藍屏代碼的原因及解決方案 Dec 25, 2023 pm 02:19 PM

詳解0x0000007f藍屏代碼的原因及解決方案

清華大學與智譜AI重磅開源 GLM-4:掀起自然語言處理新革命 清華大學與智譜AI重磅開源 GLM-4:掀起自然語言處理新革命 Jun 12, 2024 pm 08:38 PM

清華大學與智譜AI重磅開源 GLM-4:掀起自然語言處理新革命

See all articles