JS利用?React.lazy?優(yōu)化頁面初次渲染
一、需求背景
主站采用qiankun微前端方式嵌入新項目,qiankun會阻塞子應(yīng)用資源加載,這導(dǎo)致應(yīng)用白屏?xí)r間增加,希望在子應(yīng)用端進行優(yōu)化以減少白屏?xí)r間。
二、代碼分析
利用 webpack-bundle-analyzer 檢查當(dāng)前 bundle
// 安裝
npm install -D webpack-bundle-analyzer
// 配置
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
module.exports = {
plugins: [
new BundleAnalyzerPlugin()
]
}
// 使用 構(gòu)建時自動彈出
npm run build
第三方庫如echarts已經(jīng)使用按需引入方案,從代碼體積層面已無優(yōu)化空間
由圖可知,當(dāng)前 bundle 體積集中在2.6cb4c9dd.chunk.js中,有必要進行代碼分割
優(yōu)化方向:
- 使用路由懶加載,延遲加載在初次渲染時未用到的組件。
- 使用 prefetch 功能,在首頁必須資源加載完后自動加載其他路由頁面資源,防止路由跳轉(zhuǎn)白屏
三、技術(shù)實現(xiàn)
1. 路由懶加載
使用 React.lazy
const Market = React.lazy(() => import(/* webpackChunkName: "Market" */ './pages/market')) const Record = React.lazy(() => import(/* webpackChunkName: "Record" */ './pages/Myrecord')) const Detail = React.lazy(() => import(/* webpackChunkName: "Detail" */ './pages/detail'))
打包分析圖:

由圖可以看到,webpack 不僅將路由分離成了單獨的bundle,并且對依賴進行了拆解,將首屏未用到的第三方依賴,如echarts、zrender拆分到單獨的 bundle 中,只在需要的路由頁進行加載,這大大減少了首屏資源加載體積(37%),將明顯提前進入首屏渲染邏輯。
2. Prefetch 預(yù)獲取
由于路由懶加載功能將非首屏依賴抽離出來,默認(rèn)只在進入對應(yīng)路由頁面時刻進行加載,這會導(dǎo)致路由跳轉(zhuǎn)時出現(xiàn)白屏或者loading,影響用戶體驗。所以我們使用 Prefetch預(yù)獲取功能來幫助解決這個問題。
使用 webpackPrefetch:告訴瀏覽器將來可能需要該資源來進行某些導(dǎo)航跳轉(zhuǎn)
const Market = lazy(() => import(/* webpackPrefetch: true, webpackChunkName: "Market" */ './pages/market')) const MyRecord = lazy(() => import(/* webpackPrefetch: true, webpackChunkName: "MyRecord" */ './pages/record')) const Detail = lazy(() => import(/* webpackPrefetch: true, webpackChunkName: "Detail" */ './pages/detail'))
在首頁資源加載完成后,其他路由頁資源會以低優(yōu)先級的順序在后臺下載。在跳轉(zhuǎn)其他頁面時,可以快速從命中緩存,從而提前進入渲染邏輯。提升用戶體驗。
到此這篇關(guān)于JS利用 React.lazy 優(yōu)化頁面初次渲染的文章就介紹到這了,更多相關(guān)JS React.lazy 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript直接調(diào)用函數(shù)與call調(diào)用的區(qū)別實例分析
這篇文章主要介紹了JavaScript直接調(diào)用函數(shù)與call調(diào)用的區(qū)別,結(jié)合額實例形式分析了JavaScript直接調(diào)用函數(shù)與call調(diào)用的基本用法、區(qū)別及相關(guān)注意事項,需要的朋友可以參考下2020-05-05
JavaScript正則表達(dá)式和級聯(lián)效果
正則表達(dá)式(regular expression)是一種字符串匹配的模式,用來檢查一個字符串中是否包含指定模式的字符串。下面通過本文給大家分享JavaScript_正則表達(dá)式和級聯(lián)效果,感興趣的朋友一起看看吧2017-09-09
JS實現(xiàn)二叉查找樹的建立以及一些遍歷方法實現(xiàn)
本篇文章主要介紹了JS實現(xiàn)二叉查找樹的建立以及一些遍歷方法實現(xiàn),具有一定的參考價值,感興趣的小伙伴們可以參考一下。2017-04-04

