React性能之--如何避免组件重复渲染?

embedded/2024/10/18 19:23:59/

         在react中,我们会发现存在组件重复渲染,虽然说如果项目不大的话,这点影响不大,但是我们还是尽量避免组件渲染比较好,养成好习惯,尽可能让不管是大小项目,都让性能尽可能优化 。那我们如何避免组件重复渲染呢?

   一、在 React 中,可以通过以下几种方法来避免组件重复渲染:

      1、PureComponent 或 React.memo:这些是 React 提供的优化组件渲染的高阶组件。                  (1)PureComponent:会自动实现了shouldComponentUpdate方法,进行浅比较来判断是否需要重新渲染组件,PureComponent 在 shouldComponentUpdate 方法中对组件的 propsstate 进行浅比较。在React 16.8之前,建议使用PureComponent来优化组件性能。

          (2)React.memo:在React 16.8之后,引入了React.memo。React.memo是一个高阶组件,用于包装函数组件。它与PureComponent类似,也会进行浅比较来判断是否需要重新渲染组件,它对函数组件进行浅比较。如果 props 或 state 没有变化,组件将不会重新渲染。

      注意:React 16.8开始,推荐使用React.memo优化函数组件性能,而不再需要使用PureComponent

     2、 shouldComponentUpdate:在类组件中,可以手动实现 shouldComponentUpdate 方法来判断组件是否需要重新渲染。在该方法中,可以比较前后的 props 和 state,如果它们没有变化,可以返回 false 阻止组件重新渲染。

     3、 React 的 Context API:Context 可以避免跨层级组件不必要渲染。通过在上层组件中使用 Context.Provider,可以将需要共享的数据传递给子组件。子组件可以通过 Context.Consumer useContext Hook获取这些数据,而不需要通过 props 传递。

      总的来说,避免组件重复渲染关键减少不必要渲染触发。可以通过使用PureComponent 或 React.memo 来自动检测变化,并且在需要的地方手动实现 shouldComponentUpdate 方法或使
用 Context 来控制渲染。

二、使用

    1、PureComponent 或 React.memo

 2、 shouldComponentUpdate:

例子:在这个例子中,如果nameage没有改变,那么组件的render方法将不会被调用。这对于避免不必要的渲染可以提高性能

 3、 React 的 Context API

假设我们有一个简单的计数器组件,它包含一个按钮,点击按钮会增加计数器的值。现在我们希望将计数器的值传递给组件树中的其他组件,而不需要通过props将值逐级传递。

使用React的Context API可以实现这个目的。

(1)我们创建一个Context对象

(2)计数器组件:然后,在计数器组件中,我们将CounterContext.Provider包装在按钮周围,并将计数器的值作为value传递给Provider

(3)使用CounterContext.Consumer:现在,我们可以在任何想要访问计数器值的组件中使用CounterContext.Consumer

这样,每当我们点击增加计数器按钮时,只有DisplayCount组件会重新渲染,而不是整个组件树。这是通过Context API提供的跨组件传递数据的机制,它可以避免重复渲染整个组件树。


http://www.ppmy.cn/embedded/93423.html

相关文章

【RISC-V设计-08】- RISC-V处理器设计K0A之BMU

【RISC-V设计-08】- RISC-V处理器设计K0A之BMU 文章目录 【RISC-V设计-08】- RISC-V处理器设计K0A之BMU1.简介2.顶层设计3.端口说明4.总线时序4.1 总线写时序4.2 总线读时序 5.代码设计6.总结 1.简介 总线管理单元(Bus Management Unit,简称 BMU&#x…

力扣高频SQL 50题(基础版)第四十一题之1517.查找拥有有效邮箱的用户

文章目录 力扣高频SQL 50题(基础版)第四十一题1517.查找拥有有效邮箱的用户题目说明实现过程准备数据实现方式结果截图总结 力扣高频SQL 50题(基础版)第四十一题 1517.查找拥有有效邮箱的用户 题目说明 表: Users -----------…

Redis实现IP限流的两种方式详解

gateway网关ip限流 通过reids实现 限流的流程图 在配置文件配置限流参数 blackIP:# ip 连续请求的次数continue-counts: ${counts:3}# ip 判断的时间间隔,单位:秒time-interval: ${interval:20}# 限制的时间,单位:秒limit-time…

FPGA第4篇,中国FPGA芯片市场,发展分析与报告

前言 FPGA(Field-Programmable Gate Array),即现场可编程门阵列,是一种可由用户配置的集成电路,具有高度的灵活性和强大的计算能力,被广泛应用于通信、航空航天、汽车电子、消费电子、数据中心、人工智能等…

MongoDB笔记1——MongoDB简介

MongoDB 什么是MongoDB 2007年10月,MongoDB由10gen团队所开发,2009年2月首度推出。 基于分布式文件存储的数据库由C语言编写。旨在为WEB应用提供可拓展的高性能数据存储解决方案。 MongoDB是一个介于关系数据库和非关系数据库(NoSQL&…

write_sdc和write_script区别

文章目录 一、set_disable_clock_gating_check二、write_sdc和write_script区别1. write_sdc2. write_script 一、set_disable_clock_gating_check set_disable_clock_gating_check对指定的cell/pin/lib_cell/lib_pin设置是否进行clock gating的时序检查。 对于工具插入或者…

Python中各类常用内置转换函数

Python中各类常用内置转换函数 函数功能说明int(x)将 x 转换为整数类型float(x)将 x 转换为浮点数类型str(x)将 x 转换为字符串repr(x)将 x 转换为表达式字符串eval(str)计算在字符串中的有效Python表达式,并返回一个对象list(s)将序列 s 转换为一个列表tuple(s)将…

Linux与Docker常用运维命令一览

大家好,欢迎各位工友。 在博主陆陆续续的运维过程中,经常会用到许多运维相关的命令,以往都是现用现查,如今抽时间都记录一下,便于查阅和使用。 Linux常用命令 文件和目录操作 ls:列出目录内容cd [direc…