溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

react 實(shí)現(xiàn)頁(yè)面代碼分割、按需加載的方法

發(fā)布時(shí)間:2020-10-26 07:32:34 來(lái)源:腳本之家 閱讀:234 作者:BingqiChen 欄目:web開(kāi)發(fā)

雖然一直有做 react 相關(guān)的優(yōu)化,按需加載、dll 分離、服務(wù)端渲染,但是從來(lái)沒(méi)有從路由代碼分割這一塊入手過(guò),昨天在本地開(kāi)發(fā)時(shí)沒(méi)有測(cè)試成功,今天又搞了下,已經(jīng)部署到線上環(huán)境了,今天就這個(gè)記錄一下。

修改配置

開(kāi)發(fā)環(huán)境:webpack@v3 、react-router@v4

安裝依賴(lài):

$ yarn add babel-plugin-syntax-dynamic-import -dev

修改 .babelrc 文件:在 plugins 中添加 "syntax-dynamic-import"

改造項(xiàng)目代碼

安裝依賴(lài):

$ yarn add react-loadable

根據(jù) react-loadable 文檔提示,我們需要提供一個(gè)載入新頁(yè)面時(shí)的 Loading 組件,同時(shí)對(duì)加載和超時(shí)狀態(tài)進(jìn)行區(qū)別提示:

import React from 'react';
import { Icon } from 'antd';

const Loading = ({ pastDelay, timedOut, error }) => {
 if (pastDelay) {
 return <div><Icon type="loading" /></div>;
 } else if (timedOut) {
 return <div>Taking a long time...</div>;
 } else if (error) {
 return <div>Error!</div>;
 }
 return null;
};

更改頁(yè)面組件導(dǎo)入方法:

import React from 'react';
import Loadable from 'react-loadable';
import { Route, Switch } from 'react-router-dom';

const Home = Loadable({
 loader: () => import('../Home'),
 loading: Loading,
 timeout: 10000
});
const EditArticle = Loadable({
 loader: () => import('../EditArticle'),
 loading: Loading,
 timeout: 10000
});

...

<Switch>
 <Route exact path="/home" component={Home} />
 <Route path="/editarticle" component={EditArticle} />
</Switch>

然后打包結(jié)果就會(huì)分離出各頁(yè)面代碼:

react 實(shí)現(xiàn)頁(yè)面代碼分割、按需加載的方法

在頁(yè)面中我們只需要載入入口文件 app.js ,其他腳本在訪問(wèn)到對(duì)應(yīng)頁(yè)面時(shí)都會(huì)經(jīng)由這個(gè)文件載入。

驗(yàn)證結(jié)果

在將靜態(tài)資源上傳到 cdn 之后,在頁(yè)面中加載 app.css 和 app.js ,運(yùn)行之后訪問(wèn)各個(gè)頁(yè)面就會(huì)依次加載對(duì)應(yīng)腳本,結(jié)果如圖:

react 實(shí)現(xiàn)頁(yè)面代碼分割、按需加載的方法

可以看到,在訪問(wèn)第一個(gè)頁(yè)面時(shí)加載的頁(yè)面腳本經(jīng) gzip 壓縮后僅有 21.8KB ?。?!當(dāng)然這與頁(yè)面復(fù)雜度也有關(guān),但是相較于加載全部腳本,已經(jīng)是大幅減少了,這種優(yōu)化對(duì)訪問(wèn)目標(biāo)性很強(qiáng)的用戶(hù)感受起來(lái)尤為明顯。

這么做的另一個(gè)好處就是當(dāng)我們只更改項(xiàng)目中某些頁(yè)面的業(yè)務(wù)代碼時(shí),其他頁(yè)面的代碼依然是不變的,所以這個(gè)時(shí)候其他頁(yè)面用的是客戶(hù)端緩存,從另一個(gè)層面又做了一次優(yōu)化。

Tips

react-loadable 還有其他配置選項(xiàng),可以按需配置;

這里還需要注意的一點(diǎn)是:webpack 中的 output.publicPath 選項(xiàng),這個(gè)配置會(huì)影響 app.js 從何處加載頁(yè)面腳本,正確的寫(xiě)法應(yīng)該是腳本文件載入的前綴地址,例如: 0.js 的遠(yuǎn)程鏈接為 http://static.domain.com/release/0.js ,那么這個(gè)應(yīng)該配置為http://static.domain.com/release/。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI