React 18 中常见的生命周期方法

news/2024/7/15 17:12:44 标签: react.js, 前端, 前端框架

1. 挂载阶段(Mounting Phase)

constructor()

constructor() 是 React 组件的构造函数,用于初始化组件的状态和绑定方法。在组件实例创建时调用,且只会调用一次。

static getDerivedStateFromProps()

static getDerivedStateFromProps() 是一个静态方法,用于根据 props 的变化来更新组件的状态。在组件实例创建和更新阶段都会被调用。

render()

render() 方法负责根据组件的状态和 props 来渲染组件的 UI。它是组件生命周期中的核心方法,必须实现。

componentDidMount()

componentDidMount() 在组件被挂载到 DOM 后调用,通常用于执行一些初始化操作,如网络请求、订阅事件等。

2. 更新阶段(Updating Phase)

static getDerivedStateFromProps()

与挂载阶段相同,static getDerivedStateFromProps() 也在更新阶段被调用,用于根据 props 的变化来更新组件的状态。

shouldComponentUpdate()

shouldComponentUpdate() 用于控制组件是否需要重新渲染。通过返回 true 或 false 来告诉 React 是否要更新组件,默认返回 true。

render()

render() 方法在更新阶段同样会被调用,用于重新渲染组件的 UI。

getSnapshotBeforeUpdate()

getSnapshotBeforeUpdate() 在 render 方法之后、更新 DOM 之前调用,用于获取更新前的 DOM 状态,通常与 componentDidUpdate() 配合使用。

componentDidUpdate()

componentDidUpdate() 在组件更新完成后调用,通常用于执行一些与更新相关的操作,如更新 DOM、发送网络请求等。

3. 卸载阶段(Unmounting Phase)

componentWillUnmount()

componentWillUnmount() 在组件即将从 DOM 中卸载时调用,通常用于执行一些清理工作,如取消订阅、清除定时器等。

4. 错误处理阶段(Error Handling Phase)

componentDidCatch()

componentDidCatch() 用于捕获子组件的错误,并在发生错误时进行处理。通常用于显示错误信息或记录错误日志。

5. 新增的生命周期方法(New Lifecycle Methods)

startTransition()

startTransition() 允许将某些更新标记为低优先级,以提高页面的响应性能。

useDeferredValue()

useDeferredValue() 用于处理某些状态的延迟更新,以优化性能和用户体验。

这些生命周期方法在 React 18 中为开发者提供了更多灵活性和性能优化的机会,帮助开发者更好地管理组件的行为和状态。


http://www.niftyadmin.cn/n/5477995.html

相关文章

file_get_contents(‘php://input‘); 这个postman要如何传参

在 Postman 中传递参数给 file_get_contents(php://input); 是通过请求的 Body 部分来实现的。使用 Postman 进行 API 接口测试时,可以按照以下步骤来传递参数: 打开 Postman 并创建一个新的请求。在请求的 URL 地址栏输入你的 API 地址。选择请求方法为…

P24 C# 类

(1)、类修饰符: new: public:外部可自由访问 protected: 访问限制在继承链上 internal: 在当前的项目中,可以自由访问,默认的访问级别 private: 只能修饰类的成员类(内部类的可以&#x…

图论做题笔记:bfs

Leetcode - 433:最小基因变化 题目: 基因序列可以表示为一条由 8 个字符组成的字符串,其中每个字符都是 A、C、G 和 T 之一。 假设我们需要调查从基因序列 start 变为 end 所发生的基因变化。一次基因变化就意味着这个基因序列中的一个字符发生了变化…

HarmonyOS 应用开发-ArkUI(ets)仿“腾讯新闻”APP

一、效果演示 1、新闻列表页 2、新闻详情页、图片展示页 3、视频页 4、动态页 二、 流程图 –本来自定义了视频的控制栏的,但是发现VideoController()控制器的bug会导致控制器失效,所以没继续做。视频页先不搞了。 三、文件组织(“我的页面…

JavaScript(三)-Web APIS

文章目录 DOM事件进阶事件流事件流与两个阶段说明事件捕获事件冒泡阻止冒泡解绑事件 事件委托其他事件页面加载事件元素滚动事件页面尺寸事件 元素尺寸与位置 DOM事件进阶 事件流 什么是事件流 事件流指的是事件完整执行过程中的流动路径 事件流与两个阶段说明 捕获与冒泡 …

软件测试学习之MySQL学习笔记(完结)

目录 1. 数据库**** 1.1. 概念**** 1.2. 分类**** 1.2.1. 关系型数据库**** 1.2.1.1. SQL**** 1.2.2. 安装**** 1.2.2.1. Navicat**** 2. SQL语句**** 2.1. 常用数据类型**** 2.2. 数据库**** 2.3. 表**** 2.3.1. 字段约束**** 2.4. 数据**** 2.4.1. 增 insert**…

布局升级秘籍:掌握CSS Grid网格布局,打造响应式网页设计

随着现代网页设计的不断演进,传统的布局方式已经逐渐不能满足设计师和开发者们对于高效、灵活且强大布局系统的追求。而CSS Grid网格布局,正是在这样的背景下应运而生的。 今天,我们就来深入探讨CSS Grid布局的魅力所在,带你解锁…

力扣刷题 二叉树层序遍历相关题目

NO.107 二叉树的层次遍历 II 给定一个二叉树,返回其节点值自底向上的层次遍历。 (即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历) 示例 1: 输入:root [3,9,20,null,null,15,7] 输出&#xff1…