基於webpack實現多html頁面開發框架六 提取公共代碼

来源:https://www.cnblogs.com/lisong/archive/2019/12/10/12015791.html
-Advertisement-
Play Games

一、解決什麼問題 1、如果a.js和b.js都引用了common.js,那在打包的時候common.js會被重覆打入到a.js和b.js,造成重覆打包 2、單獨打包common.js對性能有幫助,瀏覽器下載一次後會緩存下來,不會重覆下載 二、未抽取公共代碼的狀況 基於之前代碼,測試如下: 1、在as ...


一、解決什麼問題

  1、如果a.js和b.js都引用了common.js,那在打包的時候common.js會被重覆打入到a.js和b.js,造成重覆打包

  2、單獨打包common.js對性能有幫助,瀏覽器下載一次後會緩存下來,不會重覆下載

二、未抽取公共代碼的狀況

  基於之前代碼,測試如下:  

  1、在assets/js文件夾下新建common.js,輸入如下代碼:

1 export function printCommon(){
2     console.log("common");
3 }

  2、在src/index文件夾下的index.js引入common.js,調用printCommon

  3、在src/home文件夾下的index.js引入common.js,調用printCommon

  4、測試結果如下:

  

  很明顯common.js分別打包到了home.js和index.js,造成了重覆打包,且不能利用瀏覽器緩存的優點

三、抽取公共代碼後的狀況

  1、需要用到的插件SplitChunksPlugin,個人理解該插件主要是解決重覆引用的問題,官網詳細介紹https://webpack.js.org/plugins/split-chunks-plugin/

     詳細描述一個配置屬性chunks:拆分模塊的範圍它有三個值async、initial和all

    async表示只從非同步載入得模塊(動態載入import())裡面進行拆分

    initial表示只從入口模塊進行拆分

    all表示以上兩者都包括

  2、如何配置splitChunks,如下:

 1  // 提取公共代碼
 2     optimization: {
 3         splitChunks: {
 4             cacheGroups: {
 5                 vendor: {   // 抽離第三方插件
 6                     test: /node_modules/,   // 指定是node_modules下的第三方包
 7                     chunks: 'initial', // 拆分模塊的範圍
 8                     name: 'vendor',  // 打包後的文件名,任意命名    
 9                     // 設置優先順序,防止和自定義的公共代碼提取時被覆蓋,不進行打包
10                     priority: 10
11                 },
12                 utils: { // 抽離自己寫的公共代碼,common這個名字可以隨意起
13                     chunks: 'initial',
14                     name: 'common',  // 任意命名
15                     minSize: 0,    // 只要超出0位元組就生成一個新包
16                     minChunks: 2   //
17                 }
18             }
19         }
20     },

  3、配置完重新運行npm run dev 效果如下:

  頭部引用超過兩次的公共代碼進行了單獨打包,common.js和vendor.js

  

   再次打開home頁面,看common.js和vendor.js是否重新下載,狀態為304,引用的緩存

  

 

 

 

  

 

  源碼地址:https://github.com/James-14/webpack4_multi_page_demo

  寫的不對之處請大家批評指正~~~~!!!!!! 

 

  文章原創,轉載請註明出處,謝謝!

    


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1:利用DOM獲取該 div 的 ID,然後清空該DIV的內容(如果你需要接著裡面的內容添加可不要清空);需要註意點是清空最好用“ empty() ”; 2: 把 async設成true ,否則又一條警告的錯誤,這條錯誤導致你的內容顯示不出來;下麵就是警告的錯誤 3:就是添加HTML了。 具體代碼如 ...
  • 註:本文非本人原著;原文作者: 黃卉 《js去除空格12種方法》 ...
  • css3 實現右箭頭→ <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <style> .divtest{ position: absolute; top: ...
  • 1. 綁定事件的相容 function addEventListener(element,type,fn) { if(element.addEventListener){ element.addEventListener(type,fn,false); }else if(element.attach ...
  • 解綁事件 註意:用什麼方式綁定事件, 就應該用對應的方式解綁事件 1.解綁事件 對象.on事件名字=事件處理函數 >綁定事件 對象.on事件名字=null; //1 對象.on事件名字=事件處理函數 綁定事件 my$("btn").onclick = function () { console.lo ...
  • 總結綁定事件的區別: addEventListener(); attachEvent() 相同點: 都可以為元素綁定事件 不同點: 1.方法名不一樣 2.參數個數不一樣addEventListener三個參數,attachEvent兩個參數 3.addEventListener 谷歌,火狐,IE11 ...
  • 群聊版 安裝 pipinstallgevent-websocket 視圖 #-*-coding:utf-8-*- importjson fromflaskimportFlask,request,render_template fromgeventwebsocket.handlerimportWebS... ...
  • part4 課程介紹 事件 1. 綁定事件的區別 2. 移除綁定事件的方式及區別和相容代碼 3. 事件的三個階段 4. 事件冒泡 5. 為同一個元素綁定多個不同的事件,指向的是同一個事件處理函數 6. 百度的大項目 7. BOM 8. 定時器 9. DOM加強,多個幾個好玩的案例 part3 複習 ...
一周排行
    -Advertisement-
    Play Games
  • Timer是什麼 Timer 是一種用於創建定期粒度行為的機制。 與標準的 .NET System.Threading.Timer 類相似,Orleans 的 Timer 允許在一段時間後執行特定的操作,或者在特定的時間間隔內重覆執行操作。 它在分散式系統中具有重要作用,特別是在處理需要周期性執行的 ...
  • 前言 相信很多做WPF開發的小伙伴都遇到過表格類的需求,雖然現有的Grid控制項也能實現,但是使用起來的體驗感並不好,比如要實現一個Excel中的表格效果,估計你能想到的第一個方法就是套Border控制項,用這種方法你需要控制每個Border的邊框,並且在一堆Bordr中找到Grid.Row,Grid. ...
  • .NET C#程式啟動閃退,目錄導致的問題 這是第2次踩這個坑了,很小的編程細節,容易忽略,所以寫個博客,分享給大家。 1.第一次坑:是windows 系統把程式運行成服務,找不到配置文件,原因是以服務運行它的工作目錄是在C:\Windows\System32 2.本次坑:WPF桌面程式通過註冊表設 ...
  • 在分散式系統中,數據的持久化是至關重要的一環。 Orleans 7 引入了強大的持久化功能,使得在分散式環境下管理數據變得更加輕鬆和可靠。 本文將介紹什麼是 Orleans 7 的持久化,如何設置它以及相應的代碼示例。 什麼是 Orleans 7 的持久化? Orleans 7 的持久化是指將 Or ...
  • 前言 .NET Feature Management 是一個用於管理應用程式功能的庫,它可以幫助開發人員在應用程式中輕鬆地添加、移除和管理功能。使用 Feature Management,開發人員可以根據不同用戶、環境或其他條件來動態地控制應用程式中的功能。這使得開發人員可以更靈活地管理應用程式的功 ...
  • 在 WPF 應用程式中,拖放操作是實現用戶交互的重要組成部分。通過拖放操作,用戶可以輕鬆地將數據從一個位置移動到另一個位置,或者將控制項從一個容器移動到另一個容器。然而,WPF 中預設的拖放操作可能並不是那麼好用。為瞭解決這個問題,我們可以自定義一個 Panel 來實現更簡單的拖拽操作。 自定義 Pa ...
  • 在實際使用中,由於涉及到不同編程語言之間互相調用,導致C++ 中的OpenCV與C#中的OpenCvSharp 圖像數據在不同編程語言之間難以有效傳遞。在本文中我們將結合OpenCvSharp源碼實現原理,探究兩種數據之間的通信方式。 ...
  • 一、前言 這是一篇搭建許可權管理系統的系列文章。 隨著網路的發展,信息安全對應任何企業來說都越發的重要,而本系列文章將和大家一起一步一步搭建一個全新的許可權管理系統。 說明:由於搭建一個全新的項目過於繁瑣,所有作者將挑選核心代碼和核心思路進行分享。 二、技術選擇 三、開始設計 1、自主搭建vue前端和. ...
  • Csharper中的表達式樹 這節課來瞭解一下表示式樹是什麼? 在C#中,表達式樹是一種數據結構,它可以表示一些代碼塊,如Lambda表達式或查詢表達式。表達式樹使你能夠查看和操作數據,就像你可以查看和操作代碼一樣。它們通常用於創建動態查詢和解析表達式。 一、認識表達式樹 為什麼要這樣說?它和委托有 ...
  • 在使用Django等框架來操作MySQL時,實際上底層還是通過Python來操作的,首先需要安裝一個驅動程式,在Python3中,驅動程式有多種選擇,比如有pymysql以及mysqlclient等。使用pip命令安裝mysqlclient失敗應如何解決? 安裝的python版本說明 機器同時安裝了 ...