shouldComponentUpdate机制

2024-08-24 08:48

本文主要是介绍shouldComponentUpdate机制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • shouldComponentUpdate机制
    • 机制
    • 使用

ReactNative系列-文章

shouldComponentUpdate机制

机制

在react开发中,经常需要对数据state状态进行改变,但是这种方式每当setState的时候都会将所有的组件重新渲染一遍,这样就会有重复渲染render的问题。

如下图组件树:

默认情况下,当执行setState()方法时,react 会重新渲染整个组件树,这造成不必要的性能开销。
黄色的节点表示我们修改了数据的节点,我们希望只重新渲染这个部分,而其它蓝色的节点是我们不希望重复渲染的。

这时候,实现shouldComponentUpdate()函数可以用来指明在什么样的确切条件下,这个组件得到重绘。当然,对于界面完全由 props 和 state 所决定的组件,你可以利用PureComponent (详情可以去看 -> Component和PureComponent的区别)来为你做这个工作。

下面先回顾react的生命周期:(图片来自网络,侵删)

可以看到在shouldComponentUpdate()函数返回true时,才会触发render钩子。

shouldComponentUpdate()函数默认返回true,可以对其进行自定义的实现:

shouldComponentUpdate(nextProps, nextState) {return nextState.someData !== this.state.someData
}
  • nextProps: 表示下一个props。
  • nextState: 表示下一个state的值。

使用

以一个自定义Title组件来分析:

class Title extends React.Component {constructor() {this.state = {name: '标题',};}render() {return (<View className="Title"><Text>{this.state.name}</Text></View>);}
}class Content extends React.Component {constructor() {this.state = {content: '内容',};}componentDidMount() {this.setState({content: '新的内容',});}render() {return (<View className="Content"><Title></Title><Text>{this.state.content}</Text></View>);}
}

当我在Content组件调用setState方法时,Content组件包括其所有的子组件(Title)都会重新render,但是Title组件里并没有state的改变,我不希望它重写render。这时候可以将Title组件改为这样:

class Title extends React.Component {constructor() {this.state = {name: '标题',};}shouldComponentUpdate(nextProps, nextState) {return nextState.name !== this.state.name;}render() {return (<View className="Title"><Text>{this.state.name}</Text></View>);}
}

这篇关于shouldComponentUpdate机制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1102005

相关文章

JAVA线程的周期及调度机制详解

《JAVA线程的周期及调度机制详解》Java线程的生命周期包括NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING和TERMINATED,线程调度依赖操作系统,采用抢占... 目录Java线程的生命周期线程状态转换示例代码JAVA线程调度机制优先级设置示例注意事项JAVA线程

Java中自旋锁与CAS机制的深层关系与区别

《Java中自旋锁与CAS机制的深层关系与区别》CAS算法即比较并替换,是一种实现并发编程时常用到的算法,Java并发包中的很多类都使用了CAS算法,:本文主要介绍Java中自旋锁与CAS机制深层... 目录1. 引言2. 比较并交换 (Compare-and-Swap, CAS) 核心原理2.1 CAS

Spring Boot 集成 mybatis核心机制

《SpringBoot集成mybatis核心机制》这篇文章给大家介绍SpringBoot集成mybatis核心机制,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值... 目录Spring Boot浅析1.依赖管理(Starter POMs)2.自动配置(AutoConfigu

Redis的安全机制详细介绍及配置方法

《Redis的安全机制详细介绍及配置方法》本文介绍Redis安全机制的配置方法,包括绑定IP地址、设置密码、保护模式、禁用危险命令、防火墙限制、TLS加密、客户端连接限制、最大内存使用和日志审计等,通... 目录1. 绑定 IP 地址2. 设置密码3. 保护模式4. 禁用危险命令5. 通过防火墙限制访问6.

JAVA实现Token自动续期机制的示例代码

《JAVA实现Token自动续期机制的示例代码》本文主要介绍了JAVA实现Token自动续期机制的示例代码,通过动态调整会话生命周期平衡安全性与用户体验,解决固定有效期Token带来的风险与不便,感兴... 目录1. 固定有效期Token的内在局限性2. 自动续期机制:兼顾安全与体验的解决方案3. 总结PS

详解Spring中REQUIRED事务的回滚机制详解

《详解Spring中REQUIRED事务的回滚机制详解》在Spring的事务管理中,REQUIRED是最常用也是默认的事务传播属性,本文就来详细的介绍一下Spring中REQUIRED事务的回滚机制,... 目录1. REQUIRED 的定义2. REQUIRED 下的回滚机制2.1 异常触发回滚2.2 回

基于Redis自动过期的流处理暂停机制

《基于Redis自动过期的流处理暂停机制》基于Redis自动过期的流处理暂停机制是一种高效、可靠且易于实现的解决方案,防止延时过大的数据影响实时处理自动恢复处理,以避免积压的数据影响实时性,下面就来详... 目录核心思路代码实现1. 初始化Redis连接和键前缀2. 接收数据时检查暂停状态3. 检测到延时过

Redis中哨兵机制和集群的区别及说明

《Redis中哨兵机制和集群的区别及说明》Redis哨兵通过主从复制实现高可用,适用于中小规模数据;集群采用分布式分片,支持动态扩展,适合大规模数据,哨兵管理简单但扩展性弱,集群性能更强但架构复杂,根... 目录一、架构设计与节点角色1. 哨兵机制(Sentinel)2. 集群(Cluster)二、数据分片

深入理解go中interface机制

《深入理解go中interface机制》本文主要介绍了深入理解go中interface机制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前言interface使用类型判断总结前言go的interface是一组method的集合,不

C# async await 异步编程实现机制详解

《C#asyncawait异步编程实现机制详解》async/await是C#5.0引入的语法糖,它基于**状态机(StateMachine)**模式实现,将异步方法转换为编译器生成的状态机类,本... 目录一、async/await 异步编程实现机制1.1 核心概念1.2 编译器转换过程1.3 关键组件解析