中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

React代碼拆分的方法有哪些

發布時間:2023-03-06 16:40:33 來源:億速云 閱讀:108 作者:iii 欄目:開發技術

本篇內容介紹了“React代碼拆分的方法有哪些”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

動態加載(import)

es6提供import()函數,它是運行時執行,也就是說,什么時候運行到這一句,就會加載指定的模塊。
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還有些區別

React Lazy 和 React Suspense

React Lazy是react官方提供的解決方案,非常推薦使用該方案去做代碼拆分.需要React.Suspense配合, 該組件可以指定加載指示器(loading indicator),以防其組件樹中的某些子組件尚未具備渲染條件。使用方式如下

// 該組件是動態加載的
const OtherComponent = React.lazy(() => import('./OtherComponent'));
function MyComponent() {
  return (
    // 顯示 <Spinner> 組件直至 OtherComponent 加載完成
    <React.Suspense fallback={<Spinner />}>
      <div>
        <OtherComponent />
      </div>
    </React.Suspense>
  );
}

“React代碼拆分的方法有哪些”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

苍南县| 河西区| 尉犁县| 太原市| 淮北市| 荆州市| 铜梁县| 卓资县| 黎城县| 株洲市| 高碑店市| 渑池县| 庄浪县| 洮南市| 高陵县| 赣榆县| 仙游县| 甘南县| 洛宁县| 通榆县| 桦南县| 蓬莱市| 巴林右旗| 江阴市| 顺义区| 永仁县| 修水县| 兴城市| 堆龙德庆县| 枞阳县| 子长县| 沂源县| 环江| 诸城市| 河西区| 项城市| 乌拉特中旗| 曲水县| 呼伦贝尔市| 万盛区| 华阴市|