”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 掌握 React 重新渲染:如何避免常见陷阱

掌握 React 重新渲染:如何避免常见陷阱

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

Mastering React Re-renders: How to Avoid Common Pitfalls

1.介绍

想象一下:您刚刚构建了一个时尚、功能丰富的 React 应用程序,但突然间,性能开始下降。按钮感觉迟钝,数据更新时间太长,而且你不知道为什么。如果这听起来很熟悉,那么您并不孤单。如果处理不当,React 重新渲染通常是性能问题背后的无声罪魁祸首。

掌握 React 中的重新渲染对于旨在构建高效、可扩展应用程序的 Web 开发人员至关重要。让我们深入研究 React 重新渲染的工作原理,并发现优化性能、避免常见陷阱并将您的 React 应用程序转变为极快体验的实用策略。

2. React 重新渲染如何工作?

React 的重新渲染机制是其最强大的功能之一。它允许您的应用程序根据状态或属性的变化动态更新 UI。但是,如果不进行优化,此过程可能会导致不必要的重新渲染,从而导致性能下降。

简单来说,React 每次都会重新渲染:

  1. 组件的状态发生变化。
  2. 组件接收新的 props。
  3. 父组件重新渲染。

但是当组件重新渲染过于频繁时会发生什么?浏览器必须重新绘制屏幕,​​从而导致动画卡顿、交互缓慢和用户沮丧。现在,问问自己:有多少次您的应用程序感觉速度很慢,而您却无法确切地指出原因?

3.为什么过度重新渲染会损害性能

过多的重新渲染会产生多米诺骨牌效应,使您的整个应用程序变得缓慢。每次重新渲染发生时:

  1. React 使更改与虚拟 DOM 协调。
  2. 它计算对实际 DOM 进行的最少更新。
  3. 浏览器重新绘制屏幕。

在小型应用程序中,这可能不明显。但在具有深度嵌套组件和复杂状态管理的大型应用程序中,即使是最小的不必要的重新渲染也可能会形成性能瓶颈。

这是一个简单的例子:

const UserList = ({ users }) => {
  return users.map(user => 
{user.name}
); }; // Inside a parent component:

现在想象一下,每次父组件更新时,这个 UserList 都会重新呈现,即使用户没有更改。这就是问题所在。我们如何防止这种不必要的重新渲染?

4.常见陷阱(以及如何避免它们)

陷阱 1:不记忆函数和对象

每次父组件重新渲染时,它都会创建新的函数和对象引用,即使实际值没有改变。这会导致子组件不必要地重新渲染。

操作:使用 useCallback 和 useMemo 挂钩来记忆函数和对象。

const ParentComponent = () => {
  const handleClick = useCallback(() => {
    // some function logic
  }, []);

  const userDetails = useMemo(() => ({ name: "Rajesh", age: 30 }), []);

  return ;
};

为什么有效: 记忆化可以防止在每次重新渲染时创建新的函数和对象引用,从而减少子组件中不必要的渲染。

陷阱 2:将内联函数或对象作为 Props 传递

每次组件渲染时都会创建内联函数或对象,导致接收组件重新渲染,即使实际值没有更改。

操作:在组件外部声明函数和对象或使用记忆挂钩。

// Avoid this:
 console.log("clicked")} />

// Instead:
const handleClick = useCallback(() => console.log("clicked"), []);

陷阱3:未能使用React.memo

一些组件本质上是纯粹的——它们总是在给定相同的 props 的情况下渲染相同的输出。然而,如果没有 React.memo,当父组件重新渲染时,它们仍然会重新渲染。

操作:用 React.memo 包裹功能组件,以防止不必要的重新渲染。

const ChildComponent = React.memo(({ data }) => {
  return 
{data.name}
; });

为什么有效: React.memo 确保组件仅在其 props 更改时重新渲染,避免冗余渲染。

5.如何跟踪和调试 React 重新渲染

有没有想过,“为什么我的组件会重新渲染?” React DevTools 提供了一种很好的方法来跟踪渲染并了解哪里出了问题。

  1. 启用“突出显示更新”:这会显示哪些组件正在重新渲染。
  2. 使用“Profiler”选项卡:它显示渲染计时并帮助识别瓶颈。

您还可以使用像这样的自定义挂钩来记录重新渲染:

const useWhyDidYouRender = (componentName, props) => {
  const previousProps = useRef(props);

  useEffect(() => {
    if (previousProps.current !== props) {
      console.log(`${componentName} re-rendered`);
      previousProps.current = props;
    }
  });
};

6。优化 React 重新渲染的最佳实践

1.在需要时提升状态,但并非总是如此

有时,将状态提升到更高的组件会导致子组件不必要的重新渲染。相反,尽可能在本地管理状态。

2.明智地使用密钥

渲染列表时,确保每个项目都有一个稳定、唯一的 key prop。这有助于 React 通过识别哪些项目已更改来优化重新渲染。

3.避免重新渲染未安装的组件

这可能会导致内存泄漏和性能问题。使用 useEffect 清理函数来避免在未挂载的组件中重新渲染。

useEffect(() => {
  return () => {
    // cleanup logic here
  };
}, []);

7.总结:掌握 React 重新渲染

简而言之,React 重新渲染可能是性能问题的隐藏根源,但通过正确的技术,您可以防止不必要的重新渲染,保持应用程序快速运行,并确保流畅的用户体验。

  • 记忆函数和对象以避免重新渲染子组件。
  • 使用 React.memo 停止纯组件中不必要的重新渲染。
  • 利用 React DevTools 跟踪、了解和调试性能瓶颈。

8.实际应用:通过有意的重新渲染提高性能

下次你优化 React 应用程序时,请批判性地思考每次重新渲染。它们有必要吗?如果你记住这个函数会发生什么?通过应用这些策略,您将编写更精简、更快的 React 代码,并避免即使是最有经验的开发人员也会遇到的常见陷阱。


最终想法: 既然您已经了解了 React 重新渲染的细节,请继续将这些优化应用到您自己的应用程序中。您不仅会看到更好的性能,还会获得编写可扩展、可维护的 React 代码的信心!


版本声明 本文转载于:https://dev.to/paharihacker/mastering-react-re-renders-how-to-avoid-common-pitfalls-k01?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 通过简单示例了解 JavaScript 中的调用、应用和绑定
    通过简单示例了解 JavaScript 中的调用、应用和绑定
    通过简单示例了解 JavaScript 中的调用、应用和绑定 使用 JavaScript 时,您可能会遇到三种强大的方法:调用、应用和绑定。这些方法用于控制函数中 this 的值,从而更轻松地处理对象。让我们通过简单的示例来分解每种方法,以了解它们的工作原理。 1....
    编程 发布于2024-11-08
  • 大括号放置对 JavaScript 执行有什么影响?
    大括号放置对 JavaScript 执行有什么影响?
    大括号放置和 JavaScript 执行在 JavaScript 中,大括号的放置可以显着改变代码的行为和输出。如提供的代码片段所示,大括号位置的单个更改可能会导致截然不同的结果。自动分号插入和未定义返回当左大括号时被放置在一个新行上,如第一个代码片段中一样,自动分号插入开始。这是 JavaScri...
    编程 发布于2024-11-08
  • 学习弹性搜索
    学习弹性搜索
    Elasticsearch 是一个基于 Apache Lucene 库构建的强大开源搜索和分析引擎。它旨在处理大量数据并有效执行复杂的搜索。 Elasticsearch 的主要特性和功能包括: 分布式架构:Elasticsearch是一个分布式系统,可以水平扩展以处理大量数据和流量。 近实时搜索:E...
    编程 发布于2024-11-08
  • 股息率:基于Python的金融项目的重要指标
    股息率:基于Python的金融项目的重要指标
    股息率:基于Python的金融项目的重要指标 在财务分析领域,股息对许多投资者来说非常重要。特别是如果您正在开发一个处理财务数据或自动化投资策略的Python项目,计算和分析股息率可能是一个关键要素。这篇关于股息率的 Rankia 文章详细解释了该利率的运作方式以及为什么它对投资者...
    编程 发布于2024-11-08
  • 如何通过并行或分布式测试在多个浏览器中执行WebUI功能文件?
    如何通过并行或分布式测试在多个浏览器中执行WebUI功能文件?
    使用并行或分布式测试在多个浏览器中执行 WebUI 功能文件使用并行测试对多个浏览器 (Zalenium) 执行 WebUI 功能文件运行器或分布式测试,使用以下方法:并行运行器和场景大纲:使用场景大纲创建一个表,其中的行代表不同的浏览器配置。向 Karate-config.js 文件添加并行运行器...
    编程 发布于2024-11-08
  • 如何使用 CSS 自定义文本下划线颜色?
    如何使用 CSS 自定义文本下划线颜色?
    使用 CSS 自定义文本下划线颜色在网页设计中,为文本添加下划线是强调或突出显示信息的常见做法。但是,如果您想通过更改下划线的颜色来添加独特的触感该怎么办?这可能吗?是的,可以使用 CSS 更改文本下方线条的颜色。您可以使用以下两种方法:方法 1:使用 text-decoration-color最直...
    编程 发布于2024-11-08
  • 在 JavaScript 中实现点击劫持防御技术
    在 JavaScript 中实现点击劫持防御技术
    点击劫持等复杂攻击的出现使安全成为当今网络世界的首要问题。通过欺骗消费者点击与他们最初看到的内容不同的内容,攻击者部署了一种名为“点击劫持”的邪恶方法,这可能会带来灾难性的后果。此类攻击有可能诱骗人们下载恶意软件、发送私人信息,甚至做他们无意的事情,例如购买任何东西。为了防止此类攻击,JavaScr...
    编程 发布于2024-11-08
  • 为什么我的浮动 Div 不调整后续 Div 的大小?
    为什么我的浮动 Div 不调整后续 Div 的大小?
    Float 不调整 Div 大小之谜当使用 CSS float 时,假设后续元素将左对齐而不是流到新的元素上线。然而,在某些情况下,例如提供的示例,下面的 div 继续跨越整个宽度,而不是从第一个 div 的右侧开始。为了理解这种行为,我们深入研究 float 的复杂性定位。当元素浮动时(在本例中为...
    编程 发布于2024-11-08
  • 使用 PYTHON 将数据导入 MYSQL
    使用 PYTHON 将数据导入 MYSQL
    介绍 手动将数据导入数据库,尤其是当数据库中有多个表时,不仅很烦人,而且还很耗时。通过使用 python 库可以使这变得更容易。 从kaggle下载绘画数据集。绘画数据集由 8 个 csv 文件组成,我们将使用简单的 python 脚本将其导入到数据库中,而不是手动将数据导入到数据...
    编程 发布于2024-11-08
  • MySQL 基本运算符及其应用
    MySQL 基本运算符及其应用
    MySQL 运算符是开发人员的关键工具,可实现精确的数据操作和分析。它们涵盖了一系列功能,包括赋值、数据比较和复杂模式匹配。无论您是处理 JSON 数据还是根据条件过滤记录,了解这些运算符对于高效的数据库管理都至关重要。 本指南介绍了最重要的MySQL运算符,并通过实际示例演示了如何使用它们,使开...
    编程 发布于2024-11-08
  • 如何测试 Cron 作业:完整指南
    如何测试 Cron 作业:完整指南
    Cron 作业在许多系统中对于调度任务、自动化流程和按指定时间间隔运行脚本至关重要。无论您是维护 Web 服务器、自动备份还是运行例行数据导入,cron 作业都能让您的操作顺利运行。但与任何自动化任务一样,它们必须经过彻底测试以确保可靠性和准确性。 在本文中,我们将探讨如何有效地测试 cron 作...
    编程 发布于2024-11-08
  • Next.js 中间件简介:它如何工作并提供示例
    Next.js 中间件简介:它如何工作并提供示例
    我们来谈谈Nextjs中的路由。今天,我们来谈谈最强大的事物中间件之一。 Nextjs 中的中间件提供了一种强大而灵活的方法来拦截来自服务器的请求并控制请求流(重定向、URL 重写)并全局增强身份验证、标头、cookie 持久性等功能。 创建中间件 让我们创建 Middleware ...
    编程 发布于2024-11-08
  • 道具基础知识:第 1 部分
    道具基础知识:第 1 部分
    这是一个关于如何使用道具的初学者友好教程。在阅读之前了解什么是解构以及如何使用/创建组件非常重要。 Props,properties的缩写,props允许我们从父组件向子组件发送信息,还需要注意的是它们可以是任何数据类型。 必须了解为任何组件创建 prop 的语法。在 React 中,您必须使用...
    编程 发布于2024-11-08
  • Hibernate 与 Spring Boot 有何不同?
    Hibernate 与 Spring Boot 有何不同?
    Hibernate 与 Spring Boot 有何不同? Hibernate 和 Spring Boot 都是 Java 生态系统中流行的框架,但它们有不同的用途并具有不同的功能。 休眠 Hibernate 是一个对象关系映射 (ORM) 框架,它允许开发人员使用...
    编程 发布于2024-11-08
  • C++ 如何处理十进制数据类型?
    C++ 如何处理十进制数据类型?
    C 中的十进制数据类型 C 提供了各种数据类型来处理数值,但令人惊讶的是,十进制数据类型本身并不支持。在处理精确的十进制值或与使用十进制格式的系统交互时,这可能是一个限制。实现选项虽然 C 不提供内置十进制类型,但有两种与他们合作的方法:1。 C Decimal TR 扩展:某些编译器(例如 gcc...
    编程 发布于2024-11-08

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

Copyright© 2022 湘ICP备2022001581号-3