浅谈 React Suspense

React Suspense 是 React 中用于处理异步操作的功能。它可以让你"等待"某些操作,如数据获取或组件加载完成,然后再渲染组件。Suspense 的核心理念是让组件在准备好之前显示一个备用的 UI,例如加载指示器,从而提高用户体验。

1. 基本用法

1.1. 组件懒加载

React Suspense 最常见的用法是与 React.lazy 结合,实现组件的懒加载。这对于代码分割和优化应用性能特别有用。

import React, { Suspense } from 'react';
import ReactDOM from 'react-dom';const OtherComponent = React.lazy(() => import('./OtherComponent'));function App() {return (<div><Suspense fallback={<div>Loading...</div>}><OtherComponent /></Suspense></div>);
}ReactDOM.render(<App />, document.getElementById('root'));

在这个例子中,OtherComponent 是一个异步加载的组件,并且在它加载完成之前,会显示 fallback 指定的内容。

优点:

1. 减少初始加载时间;

2. 按需加载组件;

3. 自动处理加载状态;

1.2. 异步数据加载

Suspense 不仅适用于组件懒加载,还可以用于数据获取。虽然 React 官方尚未推出内置的数据获取 Suspense API,但可以与一些支持 Suspense 的数据获取库结合使用。

import React, { Suspense } from 'react';
import { fetch } from 'react-fetch';function UserProfile() {const user = fetch('/api/user').json();return (<div><h1>{user.name}</h1><p>{user.email}</p></div>);
}function App() {return (<div><Suspense fallback={<div>Loading user data...</div>}><UserProfile /></Suspense></div>);
}export default App;

在这个示例中,UserProfile 组件会等待数据获取完成后再渲染,期间显示加载指示器。

2. 高级用法

2.1. 嵌套 Suspense

你可以嵌套多个 Suspense 组件来处理不同部分的异步加载:

function App() {return (<div><Suspense fallback={<div>Loading header...</div>}><Header /><Suspense fallback={<div>Loading content...</div>}><Content /></Suspense></Suspense></div>);
}

2.2. 错误边界

结合错误边界可以更好地处理加载失败的情况:

class ErrorBoundary extends React.Component {state = { hasError: false };static getDerivedStateFromError(error) {return { hasError: true };}render() {if (this.state.hasError) {return <h1>Something went wrong.</h1>;}return this.props.children;}
}function App() {return (<ErrorBoundary><Suspense fallback={<div>Loading...</div>}><OtherComponent /></Suspense></ErrorBoundary>);
}

2.3. 工作原理

React Suspense 的工作原理基于"可中断渲染"的概念。当 React 遇到一个 Suspense 边界时:

1. 首先尝试渲染子组件;

2. 如果子组件抛出 Promise,如在数据加载或组件加载时;

3. React 会暂停该子树的渲染;

4. 显示 fallback UI;

5. 当 Promise 解决后,React 会重新尝试渲染;

4. 最佳实践

1. 有意义的加载状态:不要只使用简单的"Loading...",考虑使用骨架屏或进度指示器;

2. 粒度控制:将 Suspense 放在合适的层级,太大范围会导致整个页面显示加载状态;

3. 错误处理:始终结合错误边界使用;

4. 性能优化:对于数据获取,考虑预加载或预取数据;

5. 未来展望

React 团队正在开发更完善的 Suspense 数据获取方案,未来可能会:

1. 提供官方的数据获取 Suspense API;

2. 支持更复杂的并发渲染场景;

3. 改进服务器端渲染与 Suspense 的集成;

6. 本文总结

React Suspense 是 React 并发模式的重要组成部分,它提供了一种声明式的方式来处理异步操作。通过合理使用 Suspense,开发者可以创建更流畅的用户体验,更好地管理加载状态,并实现更高效的代码分割。

随着 React 生态系统的不断发展,Suspense 的应用场景将会更加广泛,成为现代 React 应用开发中不可或缺的工具。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/news/908584.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

机器学习的数学基础:线性模型

线性模型 线性模型的基本形式为&#xff1a; f ( x ) ω T x b f\left(\boldsymbol{x}\right)\boldsymbol{\omega}^\text{T}\boldsymbol{x}b f(x)ωTxb 回归问题 利用最小二乘法&#xff0c;得到 ω \boldsymbol{\omega} ω和 b b b的参数估计$ \boldsymbol{\hat{\omega}}…

Linux【4】------RK3568启动和引导顺序

引导顺序 RK3568 的启动流程如下&#xff1a; 加电后&#xff0c;芯片首先执行 BootROM 中的代码&#xff1b; BootROM 会尝试从配置好的外部设备&#xff08;如 NOR/NAND/eMMC/SD 卡&#xff09;加载启动程序&#xff1b; 如果这些设备都没有有效的启动代码&#xff0c;Bo…

Deepseek/cherry studio中的Latex公式复制到word中

需要将Deepseek/cherry studio中公式复制到word中&#xff0c;但是deepseek输出Latex公式&#xff0c;比如以下Latex代码段&#xff0c;需要通过Mathtype翻译才能在word中编辑。 $$\begin{aligned}H_1(k1) & H_1(k) \frac{1}{A_1} \left( Q_1 u_1(k) Q_{i1} - Q_2 u_2(k…

关于iview组件中使用 table , 绑定序号分页后序号从1开始的解决方案

问题描述&#xff1a;iview使用table 中type: "index",分页之后 &#xff0c;索引还是从1开始&#xff0c;试过绑定后台返回数据的id, 这种方法可行&#xff0c;就是后台返回数据的每个页面id都不完全是按照从1开始的升序&#xff0c;因此百度了下&#xff0c;找到了…

【机器学习】支持向量机实验报告——基于SVM进行分类预测

目录 一、实验题目描述 二、实验步骤 三、Python代码实现基于SVM进行分类预测 四、我的收获 五、我的感受 一、实验题目描述 实验题目&#xff1a;基于SVM进行分类预测 实验要求&#xff1a;通过给定数据&#xff0c;使用支持向量机算法&#xff08;SVM&#xff09;实现分…

前端开发面试题总结-JavaScript篇(二)

文章目录 其他高频问题15、JS的数据类型有哪些16、如何判断数组类型&#xff1f;17、解释 this 的指向规则18、跨域问题及解决方案19、宏任务与微任务的区别是什么&#xff1f;列举常见的宏任务和微任务。20、为什么微任务的优先级高于宏任务&#xff1f;设计目的是什么&#x…

硬件电路设计-开关电源设计

硬件电路设计-开关电源 电容选取设置输出电压电感的选取PCB布局典型电路 这里以杰华特的JW5359M 开关电源为例&#xff0c;介绍各个部分的功能电路。 当EN引脚电压低于0.4V时&#xff0c;整个稳压器关闭&#xff0c;稳压器消耗的电源电流降至1μΑ以下 电容选取 1.C1和C25构成…

phosphobot开源程序是控制您的 SO-100 和 SO-101 机器人并训练 VLA AI 机器人开源模型

​一、软件介绍 文末提供程序和源码下载 phosphobot开源程序是控制您的 SO-100 和 SO-101 机器人并训练 VLA AI 机器人开源模型。 二、Overview 概述 &#x1f579;️ Control your robot with the keyboard, a leader arm, a Meta Quest headset or via API &#x1f579;️…

数据通信基础

信道特性 1.信道带宽W • 模拟信道&#xff1a;Wf2-f1&#xff08;f2和f1分别表示&#xff1a;信道能通过的最高/最低频率&#xff0c;单位赫兹Hz&#xff09;。 • 数字信道&#xff1a;数字信道是离散信道&#xff0c;带宽为信道能够达到的最大数据传输速率&#xff0c;单位…

C++与Python编程体验的多维对比:从语法哲学到工程实践

引言&#xff1a;语言定位的本质差异 作为静态编译型语言的代表&#xff0c;C以0开销抽象原则著称&#xff0c;其模板元编程能力可达图灵完备级别&#xff0c;而Python作为动态解释型语言&#xff0c;凭借鸭子类型和丰富的标准库成为快速开发的首选。这种根本差异导致两种语言…

TP6 实现一个字段对数组中的多个值进行LIKE模糊查询(OR逻辑)

在ThinkPHP6中&#xff0c;可以通过以下方式实现一个字段对数组中的多个值进行LIKE模糊查询&#xff08;OR逻辑&#xff09;&#xff1a; 1&#xff0c;使用数组形式的where条件&#xff0c;通过第三个参数指定逻辑关系&#xff1a; $where[] [字段名, like, [%值1%, %值2%]…

接口不是json的内容能用Jsonpath获取吗,如果不能,我们选用什么方法处理呢?

JsonPath 是一种专门用于查询和提取 JSON 数据的查询语言&#xff08;类似 XPath 用于 XML&#xff09;。以下是详细解答&#xff1a; ​JsonPath 的应用场景​ ​API 响应处理​&#xff1a;从 REST API 返回的 JSON 数据中提取特定字段。​配置文件解析​&#xff1a;读取 J…

TCP/IP 与高速网络

题目用 “与” 而不是 “是” 连接两名词&#xff0c;说明它们天然互斥&#xff0c;就比如看到 “经理与人” &#xff0c;自然而然的就会觉得经理接近了神。 数据在 TCP/IP 网络上传输获得的 “尽力而为” 承诺的时间在端到端时延中占比太大&#xff0c;以至于针对 TCP/IP 的…

Vue3 (数组push数据报错) 解决Cannot read property ‘push‘ of null报错问题

解决Cannot read property ‘push‘ of null报错问题 错误写法 定义变量 <script setup>const workList ref([{name:,value:}])</script>正确定义变量 <script setup>const workList ref([]) </script>解决咯~

React前端框架

React&#xff1a;构建现代用户界面的范式革命&#xff08;深度解析&#xff09; 引言&#xff1a;前端开发的范式转变 在2013年之前&#xff0c;前端开发领域被jQuery等库主导&#xff0c;开发者通过命令式编程直接操作DOM元素。这种模式存在两大痛点&#xff1a;代码可维护…

Redis:string数据类型

&#x1f308; 个人主页&#xff1a;Zfox_ &#x1f525; 系列专栏&#xff1a;Redis &#x1f525; String字符串 &#x1f9d1;‍&#x1f4bb; 字符串类型是Redis最基础的数据类型&#xff0c;关于字符串需要特别注意&#xff1a; ⾸先Redis中所有的键的类型都是字符串类…

获取 OpenAI API Key

你可以按照以下步骤来获取 openai.api_key&#xff0c;用于调用 OpenAI 的 GPT-4、DALLE、Whisper 等 API 服务&#xff1a; &#x1f9ed; 获取 OpenAI API Key 的步骤&#xff1a; ✅ 1. 注册或登录 OpenAI 账号 打开 https://platform.openai.com/ 使用你的邮箱或 Google/…

window安装docker\docker-compose

安装前配置 打开控制面板,参照下图打开“启动或关闭windows功能”,Hyper-V 和容器需要启用 程序和功能 启动或关闭windows功能 勾选Hyper-V 安装路径配置 Docker在Windows上的默认安装路径为C:\Program Files\Docker。 以管理员身份运行CMD在D盘,dev文件夹下创建Docker文…

Xxl-job——源码设计思考

摘要 本文深入探讨了XXL-Job框架的设计思考&#xff0c;分析了其不使用Lombok的Data注解的原因&#xff0c;包括明确控制代码结构、避免依赖侵入、增强可维护性和调试便利性、保持编译清晰以及遵循项目历史和团队编码规范。文章还详细介绍了XXL-Job的优化设计&#xff0c;包括…

九、【ESP32开发全栈指南: UDP通信服务端】

一、TCP与UDP核心差异 特性TCPUDP连接方式面向连接 (需三次握手)无连接可靠性可靠传输 (重传/排序/校验)尽力交付 (不保证可靠性)实时性延迟较高低延迟&#xff0c;实时性强传输效率协议开销大头部开销小 (仅8字节)连接类型点对点支持广播/多播资源占用高 (需维护连接状态)极低…