JS利用?React.lazy?優(yōu)化頁面初次渲染
一、需求背景
主站采用qiankun
微前端方式嵌入新項目,qiankun
會阻塞子應(yīng)用資源加載,這導(dǎo)致應(yīng)用白屏?xí)r間增加,希望在子應(yīng)用端進(jìn)行優(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
中,有必要進(jìn)行代碼分割
優(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,并且對依賴進(jìn)行了拆解,將首屏未用到的第三方依賴,如echarts
、zrender
拆分到單獨的 bundle 中,只在需要的路由頁進(jìn)行加載,這大大減少了首屏資源加載體積(37%),將明顯提前進(jìn)入首屏渲染邏輯。
2. Prefetch 預(yù)獲取
由于路由懶加載功能將非首屏依賴抽離出來,默認(rèn)只在進(jìn)入對應(yīng)路由頁面時刻進(jìn)行加載,這會導(dǎo)致路由跳轉(zhuǎn)時出現(xiàn)白屏或者loading
,影響用戶體驗。所以我們使用 Prefetch
預(yù)獲取功能來幫助解決這個問題。
使用 webpackPrefetch
:告訴瀏覽器將來可能需要該資源來進(jìn)行某些導(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)其他頁面時,可以快速從命中緩存,從而提前進(jìn)入渲染邏輯。提升用戶體驗。
到此這篇關(guān)于JS利用 React.lazy 優(yōu)化頁面初次渲染的文章就介紹到這了,更多相關(guān)JS React.lazy 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript框架設(shè)計讀書筆記之模塊加載系統(tǒng)
本文是司徒正美的《javascript框架設(shè)計》的第二章模塊加載系統(tǒng)的讀書筆記,根據(jù)自己的理解,簡要的跟大家講述了本章的主要內(nèi)容,方便大家更好的學(xué)習(xí)。2014-12-12淺談Javascript中Object與Function對象
JavaScript的面向?qū)ο笫腔谠蔚?,所有對象都有一條屬于自己的原型鏈。Object與Function可能很多看Object instanceof Function , Function instanceof Object都為true而迷惑,所以首先看下對象的實例2015-09-09取消Bootstrap的dropdown-menu點擊默認(rèn)關(guān)閉事件方法
今天小編就為大家分享一篇取消Bootstrap的dropdown-menu點擊默認(rèn)關(guān)閉事件方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08