React?代碼拆分的幾種方法示例詳解
前沿
當我們項目越來越大的時候,代碼的體積會變得龐大,導致我們項目的加載速度變慢,特別是如果您包含大型第三方庫。您需要密切關注包含在bundle中的代碼,以免我們的項目體積太大,導致加載時間長,影響用戶體驗。在React項目中,我們可以通過以下幾種方式對代碼進行拆分,可以將代碼拆分成小的塊。讓我們的網站速度變快。
動態(tài)加載(import)
es6提供import()函數,它是運行時執(zhí)行,也就是說,什么時候運行到這一句,就會加載指定的模塊。
import()返回一個 Promise 對象。在React中,我們可以這樣去做。通過打包工具,會在打包的過程中對PageModuels生成單獨的文件,在運行的時候異步加載
import React, { useState, useEffect } from 'react';
const Index = () => {
const [Cmp, setCmp] = useState(null);
useEffect(() => {
import('./PageModules').then((mod) => setCmp(mod.default));
}, []);
return Cmp ? <Cmp /> : <div>Loading...</div>;
};
loadable component
Loadable Components是一個高階組件,允許您將代碼拆分為更小的塊并按需加載,支持服務端渲染,使用方式比較簡單。
import loadable from '@loadable/component'
const OtherComponent = loadable(() => import('./OtherComponent'))
function MyComponent() {
return (
<div>
<OtherComponent />
</div>
)
}
它和我們接下來要介紹的React.lazy還有些區(qū)別,可參考 loadable-components.com/docs/loadab…
React Lazy 和 React Suspense
React Lazy是react官方提供的解決方案,非常推薦使用該方案去做代碼拆分.需要React.Suspense配合, 該組件可以指定加載指示器(loading indicator),以防其組件樹中的某些子組件尚未具備渲染條件。使用方式如下
// 該組件是動態(tài)加載的
const OtherComponent = React.lazy(() => import('./OtherComponent'));
function MyComponent() {
return (
// 顯示 <Spinner> 組件直至 OtherComponent 加載完成
<React.Suspense fallback={<Spinner />}>
<div>
<OtherComponent />
</div>
</React.Suspense>
);
}
參考
結束語
如果是新的項目且不需要服務端渲染,推薦使用React.lazy。如果需要服務端渲染的話,推薦使用loadable component。小伙伴們可以分析下你們項目的依賴,把一些模塊拆成獨立的模塊,減少代碼體積。
以上就是React 代碼拆分的幾種方法示例詳解的詳細內容,更多關于React 代碼拆分的資料請關注腳本之家其它相關文章!
相關文章
簡析React Native startReactApplication 方法
這篇文章主要介紹了React Native startReactApplication 方法簡析,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-09-09
淺談React的React.FC與React.Component的使用
本文主要介紹了React的React.FC與React.Component的使用,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09
React在弱網環(huán)境下限制按鈕多次點擊,防止重復提交問題
這篇文章主要介紹了React在弱網環(huán)境下限制按鈕多次點擊,防止重復提交問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06
React?Hooks之usePolymerAction抽象代碼結構設計理念
這篇文章主要為大家介紹了React?Hooks之usePolymerAction抽象代碼結構設計理念,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09

