14 代碼分割之lazy:Suspense與路由懶加載

lazy內置方法 Suspense內置組件

  • lazy是React提供的懶(動態)加載組件的方法,React.lazy()

  • 能減少打包體積、延遲加載首屏不需要渲染的組件

  • 依賴內置組件Suspense:給lazy加上loading指示器組件的一個容器組件

  • Suspense目前只和lazy配合實現組件等待加載指示器的功能

  • React.lazy 接受一個函數,這個函數需要動態調用 import()。它必須返回一個 Promise,該 Promise 需要 resolve 一個 default export 的 React 組件。所以要用類返回render而不是函數

  • index.jsx

import Loading from './loading'
const MyMain = React.lazy(() => import('./main.jsx'))
function App() {return (<div>{/* 注意 fallback這里是組件 */}<React.Suspense fallback={<Loading />}><MyMain /></React.Suspense></div>)
}ReactDOM.render(<App />,document.getElementById('app')
)
  • main.jsx
// export function Main() {
//     return (
//         <div>
//             顯示內容
//         </div>
//     )
// }
// React.lazy 接受一個函數,這個函數需要動態調用 import()。
// 它必須返回一個 Promise,該 Promise 需要 resolve 一個 default export 的 React 組件。
export default class Main extends React.Component {render() {return (<div>顯示內容</div>)}
}
  • Loading.jsx
export default function Loading() {return (<div><h1>Loading...</h1><h1>Loading...</h1><h1>Loading...</h1></div>)
}

路由懶加載

  • yarn add react-router react-router-dom
  • 本地調試時,path和文件名同名,會變成訪問文件
  • index.jsx
import Loading from './loading'
import React, { lazy, Suspense } from 'react'
import { BrowserRouter } from 'react-router-dom'
import { Switch, Route } from 'react-router'
const MyMain = lazy(() => import('./main.jsx'))
function App() {return (<div>{/* 注意 fallback這里是組件 */}<Suspense fallback={<Loading />}><div><MyMain /><Switch><Route path="/mypage1" component={lazy(() => import('./page1.jsx'))} /><Route path="/mypage2" component={lazy(() => import('./page2.jsx'))} /></Switch></div></Suspense></div>)
}// 路由懶加載
ReactDOM.render(<React.StrictMode><BrowserRouter><App /></BrowserRouter></React.StrictMode>,document.getElementById('app')
);

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/250878.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/250878.shtml
英文地址,請注明出處:http://en.pswp.cn/news/250878.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

三年工作的總結

其實開通博客已經有四年之久了,但遺憾的是從來沒有認真寫過一篇博客,只是在平時會瀏覽一些大牛寫過的博客。 其實我覺得做技術的定期總結自己的經驗還是很重要的。 不知不覺參加工作已經三年了,三年時間真的過得很快,想當初帶著一腔熱血,一個背包走天下,來到上海,從零開始&…

css --- 兄弟選擇器

語法: /* 查找后邊的一個兄弟元素 */ 兄弟元素 兄弟元素/* 查找后邊的所有兄弟元素 */ 兄弟元素 ~ 兄弟元素<head><style>#maindiv {color: red;}#main~div {background-color: #e0e0e0;}</style> </head> <body><div id"main"&g…

面向對象特征:封裝、多態 以及 @propetry裝飾器

&#xff08;繼承補充&#xff09;組合objfun()#對象obj.attrfoo()#對象的屬性等于另一個對象什么是組合&#xff1a; A類的對象具備某一個屬性&#xff0c;該屬性的值是B類的對象基于這種方式就把A類與B類組合到一起對象既能使用A類中的數據與功能&#xff0c;也能使用B類中的…

15 錯誤邊界與使用技巧

錯誤邊界 React16增加防止某個組件的UI渲染錯誤導致整個應用崩潰子組件發生JS錯誤&#xff0c;有備用的渲染UI錯誤邊界是組件&#xff0c;只能用class組件來寫 錯誤邊界組件捕獲錯誤的時機 渲染時生命周期函數中組件樹的構造函數中 getDerivedStateFromError 生命周期函數…

深入探究Spark -- Cluster Manger部署(最常用為YARN實現Task Scheduler)

部署方式有&#xff1a;Standalone&#xff08;Spark的Deploy模塊&#xff09;、Mesos、YARN、EC2、LocalSparkContext創建時&#xff0c;通過傳入的Master URL不同&#xff0c;創建不同的SchedulerBackend和TaskScheduler&#xff0c;在spark.SparkContext#createTaskSchuster…

es6 --- Promise.all等待多個異步任務執行

項目中遇到一個問題,要用多個http請求,獲取數據,然后將獲取的數據統一處理… 第一反應想到用promise.all來做… 下面進入主體 // 首先使用promise封裝http請求. function getListByDetecttype (params) {return new Promise((resolve, reject) > {let param params ? par…

16 代碼分割之錯誤邊界與Suspense和命名導出

代碼分割之錯誤邊界與Suspense const Main React.lazy(() > import(./main)) class ErrorBoundary extends React.Component {state {hasError: false,}static getDerivedStateFromError(err) {console.log(getDerivedStateFromError err, err)return {hasError: true}}c…

Python 原生爬蟲

Python3 實現游戲主播人氣排行榜 from urllib import request import re# 爬取某個游戲主播的人氣&#xff08;每個游戲主播的觀看人數&#xff09;排行榜 爬蟲前奏&#xff1a;明確爬蟲目的找到數據對應的網頁分析網頁的結構找到數據所在的標簽位置模擬HTTP請求&#xff0c;向…

Mac 下查看網絡端口占用情況

1、Mac 下查看網絡端口占用情況 有的時候關閉了服務器&#xff0c;但是端口還是占用&#xff0c;解決的方法是 kill 掉占用該端口的進程。 # 查看 8009 端口的占用情況 $ lsof -i:8009 可以看到&#xff0c;該端口被 id 為 4215 的進程所占用&#xff0c;這個時候直接在命令…

javascript --- 變量提升的理解

看下面一段代碼: (function () {var x foo();var foo function foo () {return "foobar";};return x; })();(不許打出來)猜猜返回結果是什么… 答案是 // foo is not a function下面來解釋為什么會這樣,首先得明白: 1.如果變量聲明了但未賦值,則會顯示undefined…

17 初探Context的使用場景

context 容器&#xff08;即上下文&#xff09; → 裝數據 → 可以傳遞到程序的多個地方程序在執行時可訪問的容器 import styles from ...則css要寫module.css&#xff0c;否則無效果&#xff1b; import from ...則css無須寫module. &#xff0c;否則無效果 使用 context.j…

分布式監控系統開發【day37】:需求討論(一)

本節內容 為什么要做監控&#xff1f; 常用監控系統設計討論監控需求討論如何實現監控服務器的水平擴展&#xff1f;監控系統架構設計一、為什么要做監控&#xff1f; 熟悉IT監控系統的設計原理開發一個簡版的類Zabbix監控系統掌握自動化開發項目的程序設計思路及架構解藕原則…

iOS:練習題中如何用技術去實現一個連線題

一、介紹 本人做的app涉及的是教育行業&#xff0c;所以關于練習題的開發肯定是家常便飯。例如&#xff0c;選擇題、填空題、連線題、判斷題等&#xff0c;每一種題型都需要技術去實現&#xff0c;沒啥多大難度&#xff0c;這里呢&#xff0c;就給出實現連線題的核心代碼吧。過…

18 Context與組合的應用場景與使用問題

contextType 指定context類型為創建的上下文&#xff0c;此時不需要用Consumer組件包裹&#xff0c;使用this.context即可訪問會向上找最近的上下文并取值最適合的場景&#xff1a;雜亂無章的組件都需要同一些數據&#xff1b;若單純為了不層層傳遞屬性&#xff0c;使用contex…

http --- 共享加密(對稱加密)的幾個概念

使用互聯網進行數據傳輸時,可能會產生以下四個問題: 1. 竊聽: A向B發送的消息,有可能在傳輸過程中被X竊聽到 2. 假冒: A收到來自B的消息有可能是X冒充的 3. 篡改: A確實收到來自B的消息,但是該消息有可能被X篡改了 4. 事后否認:B確實收到了來自A的消息,但是A是惡意用戶,當A像B…

213. House Robber II 首尾相同的偷竊問題

&#xff3b;抄題&#xff3d;&#xff1a; You are a professional robber planning to rob houses along a street. Each house has a certain amount of money stashed. All houses at this place are arranged in a circle. That means the first house is the neighbor of…

原型鏈

<!DOCTYPE html><html><head lang"en"> <meta charset"UTF-8"> <title></title></head><body><script> /* 原型中的默認屬性 原型鏈&#xff1a;當調用構造函數&#xff08;Fn()&a…

http --- 公開密鑰加密(非對稱加密)的幾個概念

公開密鑰加密: 公鑰加密,私鑰解密 公開密鑰加密的處理流程: 1. A準備通過互聯網向B發送數據 2. B生成公鑰P和私鑰S 3. B將P發送給A 4. A使用P進行加密,并將密文通過互聯網發送給B 5. B使用S進行解密得到數據公鑰加密的更具體的栗子: 1.B首先準備好公鑰P和私鑰S 2.B將公鑰發布…

19、20 Context API

安裝React Dev Tool Context對象.displayName 使用別名 不使用別名 React.createContext 創建指定的Context對象組件會找離自己最近的Provider&#xff0c;獲取其value變量名都叫value的情況&#xff0c;就近取AContext變量名有所區分&#xff0c;兩個value都可以獲取可以…

01-spring配置詳解

1 bean元素 <!--將User對象交給spring容器進行管理 --><!-- Bean元素:使用該元素描述需要spring容器管理的對象class屬性:被管理對象的完整類名.name屬性:給被管理的對象起個名字.獲得對象時根據該名稱獲得對象. 可以重復.可以使用特殊字符.id屬性: 與name屬性一模一…