【React】生命周期

embedded/2024/10/5 4:01:03/

React 16之前的生命周期分为三个阶段:挂载阶段(Mounting)、更新阶段(Updating)、卸载阶段(Unmounting)。而React 16及以后版本,引入了新的生命周期方法,同时也引入了钩子函数(Hooks),让函数式组件也能具有类组件的生命周期特性,因此react 的生命周期逐渐淡化。

1. 挂载阶段(Mounting)

在组件实例第一次被创建并插入到DOM中时触发。

  • constructor(): 组件的构造函数,在组件被创建时调用。通常用于初始化state和绑定事件处理函数。在构造函数中,需要通过super(props)调用父类的构造函数。

  • static getDerivedStateFromProps(props, state): 这是一个静态方法,用于在props发生变化时更新state。它接收props和state作为参数,并返回一个对象来更新state,或者返回null不更新state。该方法在组件实例化时和每次接收新的props时都会被调用,不管是初次挂载还是后续更新。

  • render(): 这是生命周期中唯一必须要实现的方法。它负责返回要渲染的React元素。render方法应该是一个纯函数,不应该有副作用,也不应该改变组件的状态。

  • componentDidMount(): 在组件被挂载到DOM后立即调用。常用于执行一些需要DOM节点的操作,比如网络请求、订阅事件等。

2. 更新阶段(Updating)

当组件的props或state发生变化时触发。

  • static getDerivedStateFromProps(props, state): 见上述说明。

  • shouldComponentUpdate(nextProps, nextState): 在组件接收到新的props或state时调用,用于决定是否重新渲染组件。默认返回true,表示应该重新渲染。可以在此方法中进行性能优化,比如对props或state的变化进行判断,如果不需要重新渲染则返回false。

  • **render():**见上述说明。

  • getSnapshotBeforeUpdate(prevProps, prevState): 在render方法之后、组件更新到DOM之前调用。它可以读取之前DOM的状态,并返回一个值作为参数传递给componentDidUpdate方法。

  • componentDidUpdate(prevProps, prevState, snapshot): 组件更新后调用。可以在此方法中进行DOM操作,或者对更新前后的props和state进行比较操作。

3. 卸载阶段(Unmounting)

当组件从DOM中移除时触发。

  • componentWillUnmount(): 在组件即将被卸载和销毁时调用。常用于执行一些清理操作,比如取消订阅、清除定时器等。

React 16之后的生命周期

除了上述生命周期方法外,React 16及以后版本引入了一些新的生命周期方法:

  • static getDerivedStateFromError(error): 当子组件发生错误时调用,用于捕获错误并更新state以渲染备用UI。

  • componentDidCatch(error, info): 在组件的子组件发生错误后调用,用于捕获错误信息,并记录错误。可以在此方法中执行错误处理逻辑,比如发送错误报告等。

钩子函数(Hooks)

React 16.8及以后版本引入了Hooks,它使函数式组件也能具有类组件的生命周期特性。常用的Hooks包括:

  • useState(): 用于在函数式组件中添加state。

  • useEffect(): 在组件渲染后执行副作用操作,类似于componentDidMount和componentDidUpdate的组合。

  • useContext(): 用于在函数式组件中获取上下文对象。

  • useReducer(): 类似于Redux的reducer,用于复杂的state逻辑。

  • useCallback()和useMemo(): 用于性能优化,避免在每次渲染时重新创建函数或计算。


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

相关文章

PHP中的命名空间和自动加载机制

PHP中的命名空间和自动加载机制 PHP中的命名空间和自动加载机制 PHP 作为一种流行的服务器端脚本语言,已经发展出了许多特性和功能来更好地组织和管理代码。其中,命名空间和自动加载机制是 PHP 开发者在日常工作中经常使用的两个重要特性。它们不仅提高…

深入理解安卓ARouter:集成与应用

摘要 在Android开发中,页面间的导航和参数传递是一个重要的组成部分。ARouter(Android Router)是一个轻量级、模块化的路由框架,旨在简化页面间的跳转和参数传递。本文将详细介绍安卓ARouter的概述、集成步骤、优劣分析及应用场景…

vue3的getCurrentInstance获取当前组件实例

vue3的setup中没有this时需要使用getCurrentInstance()来获取。 在 Vue 3 中,getCurrentInstance 方法可以在组合式 API(Composition API)中获取当前组件实例。这个方法返回一个包含了组件实例的对象,你可以用它来访问组件的 pro…

CTF网络安全大赛详情

网络安全已成为现代社会的一个关键挑战,随着互联网技术的飞速发展,从个人隐私保护到国家安全,网络安全的重要性日益突显。为了应对这一挑战,CTF(Capture The Flag,中文:夺旗赛)应运而…

【学习笔记二十一】EWM仓库两步拣配配置及操作展示

一、EWM两步拣配配置 1.定义两步拣配的WPT ①第一步:标准WPT2020,目标仓位是2010两步拣配的仓位,并创建存储类型2010的两步拣配的仓位 ②第二步,标准WPT2010,目标仓位9020发货区和发货的仓位 2.定义确定仓库处理类型的控制标识 3.确定仓库处理类型 4.仓库编码级别需要允…

SpringCloud系列(16)--将服务提供者Provider注册进Zookeeper

前言:在上一章节中我们说明了一些关于Eureka自我保护模式,而且自上一章节起关于Eureka的知识已经讲的差不多了,不过因为Eureka已经停更了,为了安全考虑,我们要用还在更新维护的注册中心来取代Eureka,而本章…

linux权限维持(四)

6.inetd服务后门 inetd 是一个监听外部网络请求 ( 就是一个 socket) 的系统守护进程,默认情况下为 13 端口。当 inetd 接收到 一个外部请求后,它会根据这个请求到自己的配置文件中去找到实际处理它的程序,然后再把接收到的 这个socket 交给那…

综合练习

Oracle从入门到总裁:​​​​​​https://blog.csdn.net/weixin_67859959/article/details/135209645 下面我们通过一些实战练习加深对存储过程和函数的认识 以 scott 用户下 emp 数据表为基础,创建如下过程 (1)以部门编号为输入参数,查询该部门的平均…