一文大白話講清楚webpack基本使用——9——預加載之prefetch和preload以及webpackChunkName的使用

文章目錄

  • 一文大白話講清楚webpack基本使用——9——預加載之prefetch和preload
  • 1. 建議按文章順序從頭看,一看到底,豁然開朗
  • 2. preload和prefetch的區別
  • 2. prefetch的使用
  • 3. preload的使用
  • 4. webpackChunkName

一文大白話講清楚webpack基本使用——9——預加載之prefetch和preload

1. 建議按文章順序從頭看,一看到底,豁然開朗

  • 第一篇:
  • 一文大白話講清楚啥是個webpack
  • 第二篇:
  • 一文大白話講清楚webpack基本使用——1——完成webpack的初步構建
  • 第三篇
  • 一文大白話講清楚webpack基本使用——2——css相關loader的配置和使用
  • 第四篇
  • 一文大白話講清楚webpack基本使用——3——圖像相關loader的配置和使用
  • 第五篇
  • 一文大白話講清楚webpack基本使用——4——vue-loader的配置和使用
  • 第六篇
  • 一文大白話講清楚webpack基本使用——5——babel的配置和使用
  • 第七篇
  • 一文大白話講清楚webpack基本使用——6——熱更新及其原理
  • 第八篇
  • 一文大白話講清楚webpack基本使用——7——代碼分離和懶加載
  • 第九篇
  • 一文大白話講清楚webpack基本使用——8——開發環境和生產環境的配置和區別
  • 然后看本篇,預加載之prefetch和preload

2. preload和prefetch的區別

  • 通過翻譯,prefetch是欲拉取;preload也是預加載,說白了都是預加載,那有什么區別呢
  • 區別就是相對于誰去預加載,也正因為有相對于誰,所以有有一個優先級的問題
  • 相對于誰呢,相對于他們所在的父chunk,
  • preload在父chunk加載時,并行開始加載;而prefetch是在父chunk加載完成后,在瀏覽器空閑時才加載
  • preload chunk會在父chunk中立即請求,立刻作用;而prefetch會在未來某個時刻作用
  • 所以,preload的優先級要比prefetch高。

2. prefetch的使用

  • prefetch怎么用呢,通過動態加載時進行魔法注釋
  • 我們第八篇文章講懶加載的時候,
  • 一文大白話講清楚webpack基本使用——7——代碼分離和懶加載
  • 在main.js里面通過 import(‘./modulejs/dynamic.js’).then()動態加載dynamic.js,構建后,瀏覽器先不加載chunkJS,只有點擊了btn之后才加載chunkJS
  • 現在我們讓dynamic變成prefetch加載,就是在瀏覽器空閑的時候去加載他。實現的方式是在import時使用魔法注釋
import(/* webpackPrefetch:true */  //這里通過魔法注釋,標明為prefetch'./modulejs/dynamic.js').then(res=>{//通過import動態引入返回的是一個promise對象,then方法里面的res就是我們dynamic.js 里面export出來的對象res.addOnePToBody()
})
  • 然后我們重新構建
npm run build
  • 我們運行index.html,打開調試器Elements,發現里面多了一個<link rel=“prefetch” as=“script” href='xxx.js">
    在這里插入圖片描述

  • 說明prefetch方式會議link的方式將js掛載到頁面,然后在瀏覽器空閑的時候進行下載
    在這里插入圖片描述

3. preload的使用

  • preload的使用方式跟prefetch是一樣的,通過魔法注釋
  • 我們直接上代碼
import(/* webpackPreload:true */  //這里通過魔法注釋,標明為preload'./modulejs/dynamic.js').then(res=>{//通過import動態引入返回的是一個promise對象,then方法里面的res就是我們dynamic.js 里面export出來的對象res.addOnePToBody()})

在這里插入圖片描述

  • 更好的驗證效果,我們dynamic.js里面新加一個函數
function sayHello(){console.log('I`m sayHello from dynamic.js loade by preloade')
}

在這里插入圖片描述

  • 然后再main.js里面動態引用引用
import('./modulejs/dynamic.js').then(res=>{//通過import動態引入返回的是一個promise對象,then方法里面的res就是我們dynamic.js 里面export出來的對象res.sayHello()
})

在這里插入圖片描述

  • 然后我們重新構建
npm run build
  • 在瀏覽器里面運行index.html,發現dynamic.js的chunkJS直接被加載了
    在這里插入圖片描述

** 在實際開發中,我們優先使用prefetch,等待瀏覽器空閑時再預加載**

4. webpackChunkName

  • 這個就是給動態導入的chunk取一個別名

  • 如果我們output配置filename中包含[name],那么我們就可以通過異步導入的時候制定別名

  • 同樣使用魔法注釋來實現

  • 我們現在修改output的filename,加入[name]
    在這里插入圖片描述

  • 然后動態導入dynamic.js的chunkJS時去個別名,叫rename-dynamic

import(/* webpackChunkName:"rename-dynamic" */'./modulejs/dynamic.js').then(res=>{//通過import動態引入返回的是一個promise對象,then方法里面的res就是我們dynamic.js 里面export出來的對象res.sayHello()
})

在這里插入圖片描述

  • 然后我們重新構建
npm run build
  • 發現構建的chunkJS已經加上了rename-dynamic前綴
    在這里插入圖片描述

  • 就是這個道理,在prefetch和preload里面將這個webpackChunkName,是因為都是因為使用魔法注釋

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/66679.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/66679.shtml
英文地址,請注明出處:http://en.pswp.cn/web/66679.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【Elasticsearch 】 聚合分析:桶聚合

&#x1f9d1; 博主簡介&#xff1a;CSDN博客專家&#xff0c;歷代文學網&#xff08;PC端可以訪問&#xff1a;https://literature.sinhy.com/#/?__c1000&#xff0c;移動端可微信小程序搜索“歷代文學”&#xff09;總架構師&#xff0c;15年工作經驗&#xff0c;精通Java編…

tensorflow源碼編譯在C++環境使用

https://tensorflow.google.cn/install/source?hlzh-cn查看tensorflow和其他需要下載軟件對應的版本&#xff0c;最好一模一樣 1、下載TensorFlow源碼 https://github.com/tensorflow/tensorflow 2、安裝編譯protobuf&#xff08;3.9.2&#xff09; protobuf版本要和TensorFlo…

P8738 [藍橋杯 2020 國 C] 天干地支

兩種方法 #include<bits/stdc.h> using namespace std;int main(){int year;cin>>year;string tg[10] {"geng", "xin", "ren", "gui","jia", "yi", "bing", "ding", "wu&…

Python 常用運維模塊之OS模塊篇

Python 常用運維模塊之OS模塊篇 OS 模塊獲取當前工作目錄更改當前工作目錄返回當前目錄路徑返回上一級目錄路徑遞歸生成目錄路徑刪除目錄創建目錄刪除目錄列出特定目錄下文件和子目錄刪除某個特定文件重命名某個文件獲取某個文件/目錄的信息輸出目錄路徑分隔符輸出文件行終止符…

uniapps使用HTML5的io模塊拷貝文件目錄

最近在集成sqlite到uniapp的過程中&#xff0c;因為要將sqlite數據庫預加載&#xff0c;所以需要使用HTML5的plus.io模塊。使用過程中遇到了許多問題&#xff0c;比如文件路徑總是解析不到等。尤其是應用私有文檔目錄’_doc’。 根據官方文檔&#xff1a; 為了安全管理應用的…

使用 F12 查看 Network 及數據格式

在瀏覽器中&#xff0c;F12 開發者工具的 “Network” 面板是用于查看網頁在加載過程中發起的所有網絡請求&#xff0c;包括 API 請求&#xff0c;以及查看這些請求的詳細信息和響應數據的。以下以常見的 Chrome 瀏覽器為例&#xff0c;介紹如何使用 F12 控制臺查看 Network 里…

Redis 2.6.12在Win10系統上的安裝教程

諸神緘默不語-個人CSDN博文目錄 這個版本的安裝包是跟同事要的&#xff0c;em&#xff0c;如果真的需要這個版本的話可以跟我要&#xff1a; 解壓后雙擊第一個bat文件&#xff0c;即可掛起Redis服務&#xff1a;

分布式數據庫中間件(DDM)的使用場景

華為云分布式數據庫中間件&#xff08;DDM&#xff09;是一款專注于解決數據庫分布式擴展問題的中間件服務&#xff0c;突破了傳統數據庫的容量和性能瓶頸&#xff0c;能夠實現海量數據的高并發訪問。以下是九河云總結的DDM的典型使用場景&#xff1a; 1. 互聯網應用 在電商、…

Ubuntu16.04 安裝OpenCV4.5.4 避坑

Ubuntu16.04 安裝C版OpenCV4.5.4 Ubuntu16.04 VSCode下cmakeclanglldb調試c 文章目錄 Ubuntu16.04 安裝C版OpenCV4.5.41. 下載Opencv壓縮包2. 安裝Opencv-4.5.43. 配置OpenCV的編譯環境4.測試是否安裝成功 1. 下載Opencv壓縮包 下載Opencv壓縮包&#xff0c;選擇source版本。…

RabbitMQ集群安裝rabbitmq_delayed_message_exchange

1、單節點安裝rabbitmq安裝延遲隊列 安裝延遲隊列rabbitmq_delayed_message_exchange可以參考這個文章&#xff1a; rabbitmq安裝延遲隊列-CSDN博客 2、集群安裝rabbitmq_delayed_message_exchange 在第二個節點 join_cluster 之后&#xff0c;start_app 就會報錯了 (CaseC…

QT開發:事件循環與處理機制的概念和流程概括性總結

事件循環與處理機制的概念和流程 Qt 事件循環和事件處理機制是 Qt 框架的核心&#xff0c;負責管理和分發各種事件&#xff08;用戶交互、定時器事件、網絡事件等&#xff09;。以下是詳細透徹的概念解釋和流程講解。 1. 事件循環&#xff08;Event Loop&#xff09;的概念 …

博客搭建 — GitHub Pages 部署

關于 GitHub Pages GitHub Pages 是一項靜態站點托管服務&#xff0c;它直接從 GitHub 上的倉庫獲取 HTML、CSS 和 JavaScript 文件&#xff0c;通過構建過程運行文件&#xff0c;然后發布網站。 本文最終效果是搭建出一個域名為 https://<user>.github.io 的網站 創建…

網絡通信---MCU移植LWIP

使用的MCU型號為STM32F429IGT6&#xff0c;PHY為LAN7820A 目標是通過MCU的ETH給LWIP提供輸入輸出從而實現基本的Ping應答 OK廢話不多說我們直接開始 下載源碼 LWIP包源碼&#xff1a;lwip源碼 -在這里下載 ST官方支持的ETH包&#xff1a;ST-ETH支持包 這里下載 創建工程 …

【MySQL】存儲引擎有哪些?區別是什么?

頻率難度60%???? 這個問題其實難度并不是很大&#xff0c;只是涉及到的相關知識比較繁雜&#xff0c;比如事務、鎖機制等等&#xff0c;都和存儲引擎有關系。有時還會根據場景選擇不同的存儲引擎。 下面筆者將會根據幾個部分盡可能地講清楚 MySQL 中的存儲引擎&#xff0…

【系統環境丟失恢復】如何恢復和重建 Ubuntu 中的 .bashrc 文件

r如果你遇到這種情況&#xff0c;說明系統環境的.bashrc 文件丟失恢復&#xff1a; 要恢復 ~/.bashrc 文件&#xff0c;可以按照以下幾種方式操作&#xff1a; 恢復默認的 ~/.bashrc 文件 如果 ~/.bashrc 文件被刪除或修改&#xff0c;你可以恢復到默認的版本。可以參考以下…

人工智能丨智能化測試解決方案全面解析

智能化測試解決方案通過整合前沿的人工智能技術與自動化測試技術&#xff0c;為軟件產品的測試工作帶來了前所未有的高效與智能。 智能化測試解決方案主要內容 大語言模型私有部署&#xff1a;確保文檔理解、代碼分析和測試生成過程中的安全與隱私&#xff0c;讓你無后顧之憂…

Element修改表格結構樣式集合(后續實時更新)

場景 修改前端Element組件el-table樣式 實現 線表格 <div class"tablepro"><el-table:data"tableData":header-cell-style"{ textAlign:center}"class"tablepro-table"borderstyle"width: 100%;height:100%"&g…

C++語言的語法糖

C語言的語法糖 在現代編程語言的設計中&#xff0c;語法糖&#xff08;Syntactic Sugar&#xff09;是一個非常重要的概念。它指的是一種編程語言所提供的語法特性&#xff0c;使得代碼更加簡潔易讀&#xff0c;編寫更加方便&#xff0c;而不是增加語言的功能。C作為一種強大的…

基于Redis實現短信驗證碼登錄

目錄 1 基于Session實現短信驗證碼登錄 2 配置登錄攔截器 3 配置完攔截器還需將自定義攔截器添加到SpringMVC的攔截器列表中 才能生效 4 Session集群共享問題 5 基于Redis實現短信驗證碼登錄 6 Hash 結構與 String 結構類型的比較 7 Redis替代Session需要考慮的問題 8 …

c++入門----模板深入探究與仿函數

1.模板參數加入一個變量 一般只能是int&#xff0c;double要看c的版本&#xff0c;在最新的版本下是支持double模板參數的。 2.適配器的使用 template <class T,class containerdeque<T>> class stack { public:void push_back(const T& x) {_con.push_back…