React Hooks 流程:深入探讨

许多开发人员都了解 react,但缺乏了解可能会导致对事物如何工作的假设。清楚地了解 react 中的钩子流程可以极大地提高您的代码质量。在使用 react 4 年多之后,我想分享一些关于 react hooks 流程的重要见解,这是一个经常被忽视的概念。

在深入了解 hooks 流程之前,我想回顾一下 hooks 规则

1。只在顶层调用 hooks
不要在循环、条件或嵌套内调用 hooks
函数。相反,请始终在
的顶层使用 hooks react 函数,在任何早期返回之前

2。仅从 react 函数(组件或自定义 hook)调用 hook
不要从常规 javascript 函数中调用 hook。

react hook 流程

此 react hooks 流程图有助于可视化在组件生命周期的不同阶段调用钩子的顺序。

React Hooks 流程:深入探讨

让我们探索组件生命周期的每个阶段。

初始安装
这是组件首次加载到屏幕上的时间。

React Hooks 流程:深入探讨

运行惰性初始化器
在 react 中,状态初始化在组件的整个生命周期中仅发生一次。

通过“初始化”,我的意思是 usestate 的初始值只会被分配给变量一次。

React Hooks 流程:深入探讨

这是很正常的,通常不必担心。然而,当初始化涉及复杂的计算时,例如从本地存储设置状态,它就变得更加重要。

const [userlist, setuserlist] = usestate(localstorage.getitem("userslist"))

目前,localstorage.getitem(“userslist”) 会在每次重新渲染时执行,但其结果不会分配给状态变量。这种重复评估可能会导致性能问题。为了避免这种情况,您可以向 usestate 传递一个回调函数,该回调函数只会在挂载阶段执行一次。

const [userlist, setuserlist] = usestate(() => localstorage.getitem("userslist"))

这称为状态的延迟初始化,请在此处阅读更多内容

延迟初始化有助于防止在每次重新渲染时运行不必要的初始化逻辑。

注意:仅当状态初始化涉及计算时才使用初始化函数。

渲染
在此步骤中,react 调用函数(组件)来生成该组件的虚拟 dom 表示。此过程并不直接意味着该组件在屏幕上对用户可见。相反,它涉及 react 创建一个虚拟 dom 对象来描述 ui 应该是什么样子。

这是虚拟 dom (vdom) 对象的示例:

const ComponentA = () => {  return 

Hello World!

}

vdom 对象
{
$$typeof: 符号(react.element),
键:空,
道具:{children:’你好世界!’},
参考:空,
输入:“h1”,
…..
};

react 更新 dom
在生成虚拟 dom 并协调它以获得最终的虚拟 dom 后,react 会相应地更新实际 dom。

运行 layouteffects
此步骤涉及运行 uselayouteffect 钩子,该钩子与 useeffect 类似,但在浏览器执行任何绘制之前执行,请在此处查看更多信息

浏览器绘制屏幕
浏览器将 dom 绘制到屏幕上

运行效果
这是 useeffect 挂钩运行的步骤,即在浏览器上渲染 ui 之后

如果useeffect中有状态更新,则会触发组件的更新生命周期

更新
当任何状态更新被触发时,都会触发组件的更新生命周期

React Hooks 流程:深入探讨

渲染react 更新 dom
这些步骤与安装阶段类似

清理布局效果
创建虚拟 dom (vdom) 并更新实际 dom 后,react 会运行 uselayouteffect 挂钩的清理函数。

注意:如果 uselayouteffect 的依赖没有改变,它的清理功能将不会运行。

运行 layouteffects
如果任何依赖项比较返回 false,表明发生更改,则 uselayouteffect 将再次运行;否则就不会。

浏览器绘制屏幕
此时,浏览器将更新后的 dom 渲染到屏幕上。

清理效果运行效果
仅当依赖项与之前的渲染相比发生变化时,useeffect 清理和执行才会发生。如果没有任何依赖项发生更改,则清理函数和效果都不会运行。

卸载
这是组件生命周期的最后阶段,组件将从 dom 中删除,并且不再对用户可见。

React Hooks 流程:深入探讨

清理布局效果清理效果
在从 dom 中删除组件之前,react 会为 uselayouteffect 和 useeffect 钩子运行所有清理函数。

下次您在 ui 中遇到错误时,可视化挂钩流程以查明代码中的正确位置以调查并解决问题。我希望这可以帮助您提高编码技能。快乐编码!

以上就是React Hooks 流程:深入探讨的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1499588.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 21:53:22
下一篇 2025年12月19日 21:53:38

相关推荐

  • 我的 React 之旅:第 19 天

    使用 json api 和模拟服务器进行练习 使用 json-server 是模拟后端服务器并练习 get、post、put、patch 和 delete 等 api 交互的好方法。 什么是 json-server? 一个工具,允许您快速创建一个模拟服务器来使用json数据库。非常适合原型设计和测试…

    好文分享 2025年12月19日
    000
  • React 新钩子 useActionState

    通常,在使用表单时,您需要: a) 显示加载程序 b) 显示验证错误 这通常意味着管理几个状态变量。但随着 react 19 中引入的新 useactionstate 钩子,现在有一种更简单的方法来处理它。 链接 演示 代码库 react hook:useactionstate 在以下代码片段中,请…

    2025年12月19日
    000
  • 将 Golang 延迟概念实现到 Javascript 中

    在 go 中,defer 语句推迟函数的执行,直到周围的函数返回。这是一个简单的例子: package mainimport “fmt”func main() { fmt.println(“start”) defer fmt.println(“defer 1”) defer fmt.println(…

    2025年12月19日
    000
  • 发布了一个用于 JS/TS 异步进程同步执行的库

    我发布了一个名为sync-actions 的库,它允许异步进程在 javascript/typescript 中同步执行。特别是在 typescript 中,您可以以类型安全的方式调用定义的函数。它适用于您想要在您不希望(或不能)标记为异步的函数中执行异步进程的情况。 特征 利用 node.jswo…

    2025年12月19日
    000
  • Integration Testing: Ensuring Seamless Software Interactions

    什么是集成测试 集成测试是软件测试生命周期中的关键阶段,旨在确保系统的不同模块按预期协同工作。单元测试验证各个组件,而集成测试则侧重于这些组件之间的通信和交互。本博客探讨了集成测试的重要性、类型、工具、挑战和最佳实践,全面了解其在交付高质量软件中的作用。 为什么集成测试很重要? 集成测试有助于识别组…

    2025年12月19日
    000
  • JavaScript:编程语言的“英语”

    虽然我是后端开发人员,但我的主要编程语言是 JavaScript,原因很简单:JavaScript 和英语一样,有许多不一致、历史怪癖和缺陷,但它无处不在。 阿特伍德定律:“任何可以用 JavaScript 编写的应用程序最终都将用 JavaScript 编写”。 几乎每部手机和计算机上都有一个 J…

    2025年12月19日
    000
  • 掌握 JavaScript 装饰器

    javascript 装饰器是一项强大的功能,可以简化代码并增强可读性,特别是在处理复杂的应用程序时。在这篇博客中,我们将通过实际示例来简化装饰器,使高级开发人员更容易有效地实现它们。 什么是 javascript 装饰器? 装饰器是一种用于修改类及其成员的特殊语法。它们是可应用于类、方法或属性的函…

    2025年12月19日
    000
  • EchoAPI 与 SoupUI:哪一个更适合您?

    在快节奏的软件开发中,选择合适的api测试工具至关重要。本文比较了两个流行的api测试工具:echoapi和soapui,并重点突出了echoapi的优势。我们将探讨每个工具的核心功能和优点,分析实际应用场景,并最终帮助您做出明智的选择。 EchoAPI和SoapUI概述 EchoAPI: Echo…

    2025年12月19日 好文分享
    000
  • JavaScript 循环综合指南

    JavaScript 循环结构 这份指南将深入探讨 JavaScript 中各种循环结构及其用法,并附带示例代码。 1. for 循环 当循环次数已知时,for 循环是最佳选择。 语法: for (let i = 0; i < 10; i++) { // 代码块} 示例: for (let i…

    2025年12月19日
    000
  • 掌握 JavaScript 中的 JSON 处理:解析和字符串化

    JavaScript JSON 处理:解析与字符串化详解 JSON (JavaScript 对象表示法) 是一种轻量级的数据交换格式,易于人类阅读和编写,也易于机器解析和生成。JavaScript 内置方法可实现 JSON 字符串与 JavaScript 对象的相互转换。 1. 解析 JSON 字符…

    2025年12月19日
    000
  • JavaScript 中字符串操作综合指南

    javascript 中的字符串操作 字符串操作是 javascript 中文本处理的核心方面。 javascript 提供了一组丰富的内置方法和技术来处理和转换字符串。 1.创建字符串 javascript 中的字符串可以使用单引号 (‘)、双引号 (“) 或反引号(` 用…

    好文分享 2025年12月19日
    000
  • 我如何开始作为 MERN 堆栈开发人员的旅程

    简介: “我记得第一次遇到 MERN Stack 这个术语时——MongoDB、Express.js、React.js 和 Node.js。我不知道这些工具是什么,但我知道如果我能掌握它们,我就能够构建一些令人惊叹的网络应用程序。这是我如何从初学者到深入研究 MERN Stack 开发世界的故事。”…

    2025年12月19日
    000
  • LeetCode:罗马数字到整数

    罗马数字是一种古老的数字系统,至今仍在使用。将它们转换为常规整数是一个常见的编程挑战。让我们分解一个可以优雅地处理这种转换的解决方案。 罗马数字系统 在深入代码之前,让我们先了解一下罗马数字的工作原理: 基本符号:i (1)、v (5)、x (10)、l (50)、c (100)、d (500)、m…

    2025年12月19日
    000
  • 了解 Protocol Buffers:JSON 的快速替代方案

    在数据交换领域,json(javascript 对象表示法)一直是人们的最爱。它简单、易读,并且可以跨平台无缝运行。对于许多用例来说,json 已经“足够好”。但随着系统规模的扩大以及对速度和效率的需求的增加,json 基于文本的格式可能会成为瓶颈。 这就是 protocol buffers (pr…

    2025年12月19日
    000
  • 高级 JavaScript 概念 Promise、async/await 和 try-catch

    第 8 天:高级 javascript 概念 日期:2024 年 12 月 15 日 欢迎来到第八天!今天,我们探讨一些最强大、最先进的 javascript 概念,这些概念可以提高您的编程技能。其中包括现代 es6 功能、使用 promise 和 async/await 的异步编程,以及使用 tr…

    2025年12月19日
    000
  • 大 O 符号

    它是一种表示法,决定算法运行的速度有多快或多慢。这个速度不是由秒决定的,而是由算法的运行时间随着元素的增加而增加多少决定的。 大o是时间和大小的关系。在整篇文章中,您将看到包含这些度量的图表,并且您将在实践中更好地理解它们。我们有两种类型的复杂性(空间和时间)。 时间复杂度: 确定执行与输入大小成正…

    2025年12月19日 好文分享
    000
  • 那天下雪了! ❄️

    我喜欢错综复杂的雪花。噢,它们旋转着、跳舞着,多么优雅地坠落啊!今天就和 animejs 一起下雪吧! 顾名思义,这个库允许您对几乎所有内容进行动画处理:从 css 值和 dom 属性到变量。 让我们创建一个简单的 html 文件,例如index.html: anime import anime f…

    2025年12月19日
    000
  • 如何通过代码分割提高 React 应用程序的性能

    随着 react 应用程序的大小和复杂性不断增长,其 javascript 包的大小会显着影响性能,尤其是在较慢的网络或设备上。缓解此问题的一种有效方法是通过代码拆分,这是一种将应用程序分解为更小的块的技术。这些块按需加载,减少了初始加载时间并提高了整体性能。 在本文中,我们将探讨什么是代码分割、为…

    2025年12月19日
    000
  • Documenso 和 aws-smage-upload 示例之间的 Spload 功能比较

    在本文中,我们将比较 documenso 和 aws s3 图像上传示例之间将文件上传到 aws s3 所涉及的步骤。 我们从 vercel 提供的简单示例开始。 示例/aws-s3-image-upload vercel 提供了一个将文件上传到 aws s3 的良好示例。 此示例的自述文件提供了两…

    2025年12月19日
    000
  • 掌握重做快捷键:生产力指南

    在当今快节奏的数字世界中,掌握键盘快捷键对于提高生产力和效率至关重要。虽然许多人熟悉复制、粘贴和撤消等常见快捷键,但重做快捷键通常没有得到应有的关注。本博客详细探讨了重做快捷方式,包括其用法、变体以及帮助您更智能地工作的提示。 重做快捷键是什么? 重做快捷键是撤消“撤消”操作的快速方法,让您无需手动…

    2025年12月19日
    000

发表回复

登录后才能评论
关注微信