”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 了解 React 应用程序中的渲染和重新渲染:它们如何工作以及如何优化它们

了解 React 应用程序中的渲染和重新渲染:它们如何工作以及如何优化它们

发布于2024-11-03
浏览:405

Razumevanje Renderovanja i Rerenderovanja u React Aplikacijama: Kako funkcionišu i kako ih optimizovati

当我们在 React 中创建应用程序时,我们经常会遇到术语渲染和重新渲染组件。虽然乍一看这似乎很简单,但当涉及不同的状态管理系统(如 useState、Redux)或当我们插入生命周期钩子(如 useEffect)时,事情会变得有趣。如果您希望您的应用程序快速高效,那么了解这些流程是关键。

什么是渲染?

渲染是 React 根据状态或属性在屏幕上渲染用户界面 (UI) 的过程。当你的组件第一次渲染时,它被称为第一次渲染。

初始渲染如何工作?

当组件首次“安装”到 DOM 时,会发生以下情况:

1。状态初始化:
无论你使用 useState、props 还是 Redux,都会创建组件的初始状态。

2.渲染函数:
React 循环遍历 JSX 代码并根据当前状态生成虚拟 DOM。

3.为组件的当前状态创建一个虚拟 DOM(Virtual DOM)。

4。比较(差异):
虚拟 DOM 与真实 DOM 进行比较(由于是第一次渲染,所以所有元素都会被完全渲染)。

5。显示:
该组件显示在屏幕上。
一旦组件被渲染,下一个挑战就是重新渲染。

重新渲染:何时以及为何?

每次状态或道具发生变化时都会发生重新渲染。您是否单击了更改屏幕上数字的按钮?更改了 Redux 存储中的值?所有这些操作都可能导致 React 再次渲染组件,这就是重新渲染的用武之地。

重新渲染如何工作?

状态变化检测:

  • 使用useState,当你调用setState时,React知道它需要更新组件。

  • 使用 Redux,当存储中的值发生更改时,与该状态部分关联的每个组件都会重新渲染。

渲染触发器:

当状态发生变化时,React 根据该变化创建一个新的虚拟 DOM。

比较(比较):

  • React 将新的虚拟 DOM 与旧的虚拟 DOM 进行比较,并计算要应用哪些更改。这是 React 优化渲染的一种方式。

查看更改:

  • 计算出更改后,React 将它们应用到实际的 DOM 上。因此,仅再次显示页面已更改的部分。

哪些组件被重新渲染?

并非所有组件都会受到每次更改的影响。 React 仅重新渲染那些满足以下条件的组件:

使用本地状态:
如果使用 useState,则每次调用 setState 时都会重新渲染组件。

使用 Redux 状态:
如果你的组件依赖于 Redux 状态(通过 useSelector 或 connect),当该部分状态发生变化时,它将重新渲染。

使用道具:
如果 props 值发生变化,组件将使用新值重新渲染。

渲染优化

当然,不必要地重新渲染所有组件并不总是理想的。如果我们希望应用程序快速高效地工作,这里有一些优化技巧:

1。记忆组件
React 通过 React.memo 提供组件记忆功能。如果你的组件不依赖于 props 或状态变化,你可以“记住”它,因此只有当相关值发生变化时它才会重新渲染。

例子:

const MemoizedComponent = React.memo(MyComponent);

2.函数和值的记忆

为了避免在每次渲染时重新创建函数或值,请使用 useCallback 来记忆函数并使用 useMemo 来记忆值。

  • useCallback 允许您记住函数并防止重新创建它,直到依赖项发生变化。

  • useMemo 会记住函数的结果,因此不会在每次渲染时重新计算。

例子:

const increment = useCallback(() => {
  setCount(prevCount => prevCount   1);
}, []);

const expensiveCalculation = useMemo(() => {
  return count * 2;
}, [count]);

3. Redux 优化

如果您使用 Redux,您可以使用记忆选择器(例如重新选择)进一步优化应用程序。这使得可以避免重新渲染不受状态更改影响的组件。

生命周期挂钩和渲染

在经典的React类中,我们使用shouldComponentUpdate来控制组件何时重新渲染。在功能组件中,可以使用 useEffect 和 memoization 来模拟这个概念。

结论

渲染和重新渲染对于 React 应用程序中的 UI 显示至关重要,但正确理解和优化这些过程可以区分慢速和超快的应用程序。正确使用 memoization、useCallback、useMemo 以及仔细处理 Redux,有助于避免不必要的重新渲染并保持我们的应用程序快速响应。

示例代码:渲染和重新渲染实际操作
下面是一个使用 useState、Redux 和 memoization 来优化渲染的组件示例:

import React, { useState, useEffect, useCallback, useMemo } from 'react';
import { useSelector, useDispatch } from 'react-redux';

const MyComponent = () => {
  // Lokalni state
  const [count, setCount] = useState(0);

  // Redux state
  const reduxValue = useSelector(state => state.someValue);
  const dispatch = useDispatch();

  // Memoizacija funkcije kako bi se izbeglo ponovno kreiranje na svakom renderu
  const increment = useCallback(() => {
    setCount(prevCount => prevCount   1);
  }, []);

  // Memoizacija izračunate vrednosti
  const expensiveCalculation = useMemo(() => {
    return count * 2;
  }, [count]);

  // Efekat koji se pokreće samo pri promeni reduxValue
  useEffect(() => {
    console.log("Redux value changed:", reduxValue);
  }, [reduxValue]);

  return (
    

Count: {count}

Expensive Calculation: {expensiveCalculation}

); };

正如我们所看到的,这里使用了本地状态、Redux、memoization 和 useEffect hook 的组合,以使应用程序尽可能高效。

版本声明 本文转载于:https://dev.to/jelena_petkovic/razumevanje-renderovanja-i-rerenderovanja-u-react-aplikacijama-kako-funkcionisu-i-kako-ih-optimizovati-40cj?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 模拟 Python 类
    模拟 Python 类
    最近,我不得不使用 Pytest 为 Python 模块编写单元测试。该模块包含一个类,其他类在其构造函数中初始化。 像往常一样,我为此类创建了一个固定装置,以便轻松为每个类方法编写测试。此时,当我尝试模拟构造函数中启动的不同类时,我遇到了一些问题。模拟不起作用,这些类的实例仍在创建中。 经过一些研...
    编程 发布于2024-11-03
  • 如何在单个 MySQL 查询中获取多条记录及其相关数据?
    如何在单个 MySQL 查询中获取多条记录及其相关数据?
    在一个响应中返回多个响应数据在您的 PHP 代码中,您有一个从数据库表中获取多行数据的查询。但是,您收到多个响应,并且希望将它们合并为具有多个记录的单个响应。要实现此目的,您需要修改查询以对必要的表执行左联接。您将获取主题数据并使用左连接包含相关学生信息,而不是获取学生数据。这将允许您在单个响应中包...
    编程 发布于2024-11-03
  • D - 依赖倒置原理(DIP)
    D - 依赖倒置原理(DIP)
    Before understanding DIP (Dependency Inversion Principle), it's important to know what High-Level and Low-Level modules and abstractions are. ...
    编程 发布于2024-11-03
  • 为什么 JavaScript RegEx 无法验证输入?
    为什么 JavaScript RegEx 无法验证输入?
    Javascript 中的 RegEx 功能的斗争:“Regex 不工作”的案例研究在标题中引用的查询的上下文中,“Javascript RegEx 不工作” ,”用户遇到了一个问题,即无论输入值如何,正则表达式 (regEx) 始终返回 false。查询中提供的代码片段如下:function ch...
    编程 发布于2024-11-03
  • 如何对 Ajax 请求进行排序以实现最佳控制?
    如何对 Ajax 请求进行排序以实现最佳控制?
    对 Ajax 请求进行排序迭代集合并对每个元素进行单独的 Ajax 调用时,必须控制顺序以防止服务器过载和浏览器冻结。虽然可以使用自定义迭代器,但还有更优雅的解决方案可用。jQuery 1.5 在 jQuery 1.5 及更高版本中,$.ajaxQueue() 插件利用 $ .Deferred、$....
    编程 发布于2024-11-03
  • 如何为 DOM 元素生成精确的 CSS 路径?
    如何为 DOM 元素生成精确的 CSS 路径?
    以增强的精度从 DOM 元素检索 CSS 路径提供的函数尝试为给定 DOM 元素生成 CSS 路径。然而,它的输出缺乏特异性,无法捕获元素在其兄弟元素中的位置。为了解决这个问题,我们需要一种更复杂的方法。改进的 CSS 路径函数下面介绍的增强函数解决了原来的限制:var cssPath = func...
    编程 发布于2024-11-03
  • 如何将单个 Python 字典写入具有精确标题和值行的 CSV 文件?
    如何将单个 Python 字典写入具有精确标题和值行的 CSV 文件?
    探索将 Python 字典写入 CSV 文件的细微差别您对将 Python 字典无缝写入 CSV 文件的追求给您带来了意想不到的挑战。虽然您设想在作为标题的字典键和作为第二行的值之间进行清晰的划分,但您当前的方法似乎还不够。让我们深入细节,解锁解决方案。问题在于方法的选择。 DictWriter.w...
    编程 发布于2024-11-03
  • 如何处理 Go 中延迟函数的错误返回值?
    如何处理 Go 中延迟函数的错误返回值?
    处理 Go 中返回值错误的延迟函数当返回变量的函数在没有延迟的情况下被延迟时,gometalinter 和 errcheck 正确地发出警告检查其返回的错误。这可能会导致未处理的错误和潜在的运行时问题。处理这种情况的习惯用法不是推迟函数本身,而是将其包装在另一个检查返回值的函数中。这是一个例子:de...
    编程 发布于2024-11-03
  • 为什么程序员不能总是记住代码:背后的科学
    为什么程序员不能总是记住代码:背后的科学
    如果您曾经想知道为什么程序员很难回忆起他们编写的确切代码,那么您并不孤单。尽管花费了数小时编码,许多开发人员经常忘记细节。这并不是因为缺乏知识或经验,而是因为工作本身的性质。我们来探究一下这种现象背后的原因。 编程的本质 通过记忆解决问题 这比仅仅记忆语法更能解决问题...
    编程 发布于2024-11-03
  • 你并不孤单:在社区的支持下掌握 Python
    你并不孤单:在社区的支持下掌握 Python
    加入 Python 社区可获得:社区论坛:向经验丰富的开发者获取支持和建议(如 Stack Overflow)。Discord 服务器:实时聊天室,提供即时支持和指导(如 Python Discord)。在线课程和研讨会:来自专家的指导,涵盖各种主题(如 Udemy 上的 Python NumPy ...
    编程 发布于2024-11-03
  • 学习伙伴
    学习伙伴
    聊天机器人界面,允许用户输入消息并接收来自 GPT-3.5 语言模型的对话响应。 特征 用于处理 HTTP 请求的基于 Flask 的 Web 服务器。 呈现用作用户界面的基本 HTML 模板 (chat.html)。 通过 POST 请求接受用户输入并将其发送到 OpenAI 的 GPT-3.5 ...
    编程 发布于2024-11-03
  • 前端开发 + 数据结构和算法:DSA 如何为您的 React 应用程序提供动力 ⚡
    前端开发 + 数据结构和算法:DSA 如何为您的 React 应用程序提供动力 ⚡
    专注于前端的面试通常根本不关心 DSA。 对于我们这些记得在学校/大学学习过 DSA 的人来说,所有的例子都感觉纯粹是算法(有充分的理由),但几乎没有任何例子或指导来说明我们每天使用的产品如何利用这个概念。 “我需要这个吗?” 你已经问过很多次这个问题了,不是吗? ? 以下是您今天可以在 React...
    编程 发布于2024-11-03
  • 为什么表行上的框阴影在不同浏览器中表现不同?
    为什么表行上的框阴影在不同浏览器中表现不同?
    跨浏览器表行上的框阴影外观不一致应用于表行 () 的 CSS 框阴影可能表现出不一致的行为跨各种浏览器。尽管 CSS 相同,但某些浏览器可能会按预期显示阴影,而其他浏览器则可能不会。要解决此问题,建议将 Transform 属性与 box-shadow 属性结合使用。将scale(1,1)添加到tr...
    编程 发布于2024-11-03
  • 探索 PHP 中的并发性和并行性:实践教程和技巧
    探索 PHP 中的并发性和并行性:实践教程和技巧
    理解并发性和并行性对于编写高效的 PHP 应用程序至关重要,特别是在处理需要同时处理的多个任务或操作时。这是理解和实现 PHP 并发性和并行性的分步指南,包含实践示例和说明。 1.并发与并行 并发:指系统通过交错执行同时处理多个任务的能力。这并不一定意味着任务是同时执行的,只是对它们...
    编程 发布于2024-11-03
  • ReactJs 与 Angular
    ReactJs 与 Angular
    React 和 Angular 是用于构建 Web 应用程序的两个最流行的框架/库,但它们在关键方面有所不同。以下是 React 和 Angular 之间主要区别的细分: 1. 类型:库与框架 React:一个用于构建用户界面的库,主要关注视图层。它允许开发人员将其与其他库集成以处理...
    编程 发布于2024-11-03

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3