React Hooks 的原理、常用函数及用途详解

1. ​​Hooks 是什么?​

Hooks 是 React 16.8 引入的函数式组件特性,允许在不编写 class 的情况下使用 state 和其他 React 特性(如生命周期、副作用等)。​​本质是一类特殊函数​​,它们挂载到 React 的调度系统中,在组件渲染时被调用,以“钩入”React 的核心功能。

2. ​​Hooks 的底层原理​
  • ​链表结构​​:Hooks 通过单向链表记录状态。每次组件渲染时,React 会按顺序遍历链表,读取或更新对应的状态。
  • ​调用顺序规则​​:Hooks 必须保证每次渲染的调用顺序一致(不能嵌套在条件/循环中),因为 React 依赖调用顺序来关联状态。
  • ​闭包与作用域​​:Hooks 利用闭包保存当前组件的上下文(如 useState 的 state 值)。
3. ​​常用 Hooks 及用途​
Hook 名称作用描述示例场景
useState管理组件内部状态计数器、表单输入
useEffect处理副作用(数据获取、DOM 操作等)API 请求、事件监听、定时器
useContext跨组件层级共享数据(替代部分 Redux 场景)主题切换、用户身份传递
useReducer复杂状态逻辑管理(类似 Redux 的 reducer)多状态联动、表单校验
useCallback缓存函数,避免子组件不必要的重渲染性能优化(配合 React.memo
useMemo缓存计算结果,避免重复计算复杂计算、过滤列表数据
useRef获取 DOM 引用或保存可变值(不触发渲染)聚焦输入框、保存定时器 ID
useLayoutEffect类似 useEffect,但同步执行(在 DOM 更新后、浏览器绘制前)测量 DOM 尺寸后同步更新
4. ​​Hooks 的核心用途​
  • ​逻辑复用​​:通过自定义 Hook(如 useFetch)封装可复用的逻辑,避免高阶组件(HOC)的嵌套问题。
  • ​简化组件​​:函数组件 + Hooks 替代 class 组件,代码更简洁(无需 this、生命周期方法)。
  • ​关注点分离​​:将相关逻辑聚合到独立的 Hook 中(如数据获取与状态管理分离)。
5. ​​Hooks 的本质​

Hooks 是 React 提供的一组 API,它们:

  • ​不是魔法​​:底层基于 JavaScript 的闭包和链表实现。
  • ​与 Fiber 架构协同​​:React 的 Fiber 调度机制跟踪 Hooks 的调用顺序和状态。
  • ​约束性设计​​:通过规则(如“只在顶层调用”)保证状态的一致性。
示例代码:自定义 Hook
// 自定义 Hook:监听窗口大小
function useWindowSize() {const [size, setSize] = useState({ width: window.innerWidth, height: window.innerHeight });useEffect(() => {const handleResize = () => setSize({ width: window.innerWidth, height: window.innerHeight });window.addEventListener('resize', handleResize);return () => window.removeEventListener('resize', handleResize);}, []);return size;
}// 使用
function MyComponent() {const { width } = useWindowSize();return <div>Window width: {width}px</div>;
}
注意事项
  • ​条件调用禁止​​:Hooks 必须在组件顶层调用,不可动态增减。
  • ​性能优化​​:合理使用 useMemo/useCallback 避免过度渲染。
  • ​闭包陷阱​​:useEffect 的依赖数组需正确处理(如使用 useRef 解决过期闭包)。

Hooks 的设计使 React 函数组件具备了完整能力,同时推动了前端开发向函数式编程风格的演进。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/diannao/86591.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学习路之PHP--webman协程学习

学习路之PHP--webman协程学习 一、准备二、配置三、启动四、使用 协程是一种比线程更轻量级的用户级并发机制&#xff0c;能够在进程中实现多任务调度。它通过手动控制挂起和恢复来实现协程间的切换&#xff0c;避免了进程上下文切换的开销 一、准备 PHP > 8.1 Workerman &g…

linux libusb使用libusb_claim_interface失败(-6,Resource busy)解决方案

linux libusb使用libusb_claim_interface失败&#xff08;-6&#xff0c;Resource busy&#xff09;解决方案 ✅ 问题原因&#x1f6e0;️ 解决方案&#x1f538; 方法一&#xff1a;分离内核驱动 libusb_detach_kernel_driver()&#x1f538; 方法二&#xff1a;使用 usb-devi…

使用mpu6500/6050, PID,互补滤波实现一个简单的飞行自稳控制系统

首先&#xff0c;参考ai给出的客机飞机的比较平稳的最大仰府&#xff0c;偏转&#xff0c;和防滚角度&#xff0c;如下&#xff1a; 客机的最大平稳仰俯&#xff08;Pitch&#xff09;、偏转&#xff08;Yaw&#xff09;和防滚&#xff08;Roll&#xff09;角度&#xff0c;通…

深度解析AD7685ARMZRL7:16位精密ADC在低功耗系统中的设计价值

产品概述 AD7685ARMZRL7是16位逐次逼近型&#xff08;SAR&#xff09;ADC&#xff0c;采用MSOP-10紧凑封装。其核心架构基于电荷再分配技术&#xff0c;支持2.3V至5.5V单电源供电&#xff0c;集成低噪声采样保持电路与内部转换时钟。器件采用伪差分输入结构&#xff08;IN/-&a…

EXCEL 实现“点击跳转到指定 Sheet”的方法

&#x1f4cc; WPS 表格技巧&#xff1a;如何实现点击单元格跳转到指定 Sheet 在使用 WPS 表格&#xff08;或 Excel&#xff09;时&#xff0c;我们经常会希望通过点击一个单元格&#xff0c;直接跳转到工作簿中的另一个工作表&#xff08;Sheet&#xff09;。这在制作目录页…

Python格式化:让数据输出更优雅

Python格式化&#xff1a;让数据输出更优雅 Python的格式化功能能让数据输出瞬间变得优雅又规范。不管是对齐文本、控制数字精度&#xff0c;还是动态填充内容&#xff0c;它都能轻松搞定。 一、基础格式化&#xff1a;从简单拼接开始 1. 百分号&#xff08;%&#xff09;格式…

2025年渗透测试面试题总结-小鹏[实习]安全工程师(题目+回答)

安全领域各种资源&#xff0c;学习文档&#xff0c;以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各种好玩的项目及好用的工具&#xff0c;欢迎关注。 目录 小鹏[实习]安全工程师 1. 自我介绍 2. 有没有挖过src&#xff1f; 3. 平时web渗透怎么学的&#xff0c;有…

VSCode科技风主题设计详细指南

1. 科技风设计的核心特点 科技风设计是一种强调未来感、现代感和高科技感的设计风格,在VSCode主题设计中,可以通过以下几个核心特点来体现: 1.1 色彩特点 冷色调为主:蓝色、紫色、青色等冷色调是科技风设计的主要色彩高对比度:深色背景配合明亮的霓虹色,形成强烈的视觉…

android知识总结

Activity启动模式 standard (标准模式) 每次启动该 Activity&#xff08;例如&#xff0c;通过 startActivity()&#xff09;&#xff0c;系统总会创建一个新的实例&#xff0c;并将其放入调用者&#xff08;启动它的那个 Activity&#xff09;所在的任务栈中。 singleTop (栈…

第3章 MySQL数据类型

MySQL数据类型 1、数字数据类型1.1 整数类型1.2 定点类型1.3 浮点类型1.4位值类型1.5 超出范围和溢出处理1.5.1 超出范围处理1.5.2 溢出处理 2、日期和时间数据类型3、字符串数据类型3.1 char和varchar类型3.2 binary和varbinary类型3.3 blob 和 text类型3.4 enum类型3.4.1 创建…

label-studio的使用教程(导入本地路径)

文章目录 1. 准备环境2. 脚本启动2.1 Windows2.2 Linux 3. 安装label-studio机器学习后端3.1 pip安装(推荐)3.2 GitHub仓库安装 4. 后端配置4.1 yolo环境4.2 引入后端模型4.3 修改脚本4.4 启动后端 5. 标注工程5.1 创建工程5.2 配置图片路径5.3 配置工程类型标签5.4 配置模型5.…

mysql为什么一个表中不能同时存在两个字段自增

背景。设置sort自增。会引发错误 通常自增字段都是用于表示数据的唯一性。数据库限制。需要自定义排序字段大小。

牛客round95D

原题链接&#xff1a;D-小红的区间修改&#xff08;一&#xff09;_牛客周赛 Round 95 题目背景&#xff1a; 初始拥有一个长度10^100元素全为0的数组&#xff0c;进行q查询&#xff0c;每次查询如果区间内的元素都为0就将区间变为首项为 1、公差为 1 的等差数列&#xff1b;否…

visual studio 2022更改主题为深色

visual studio 2022更改主题为深色 点击visual studio 上方的 工具-> 选项 在选项窗口中&#xff0c;选择 环境 -> 常规 &#xff0c;将其中的颜色主题改成深色 点击确定&#xff0c;更改完成

实践篇:利用ragas在自己RAG上实现LLM评估②

文章目录 使用ragas做评估在自己的数据集上评估完整代码代码讲解1. RAG系统构建核心组件初始化文档处理流程 2. 评估数据集构建3. RAGAS评估实现1. 评估数据集创建2. 评估器配置3. 执行评估 本系列阅读&#xff1a; 理论篇&#xff1a;RAG评估指标&#xff0c;检索指标与生成指…

微软PowerBI考试 PL300-在 Power BI 中清理、转换和加载数据

微软PowerBI考试 PL300-在 Power BI 中清理、转换和加载数据 Power Query 具有大量专门帮助您清理和准备数据以供分析的功能。 您将了解如何简化复杂模型、更改数据类型、重命名对象和透视数据。 您还将了解如何分析列&#xff0c;以便知晓哪些列包含有价值的数据&#xff0c;…

PostgreSQL 安装与配置全指南(适用于 Windows、macOS 与主流 Linux 发行版)

PostgreSQL 是一个功能强大、开源、稳定的对象关系数据库系统&#xff0c;广泛用于后端开发、数据处理与分布式架构中。本指南将手把手教你如何在 Windows、macOS 以及主流 Linux 发行版 上安装 PostgreSQL&#xff0c;并附上安装验证命令与基础配置方法。 一、Windows 安装与配…

WordPress博客文章SEO的优化技巧

在数字时代&#xff0c;博客不仅用于表达观点&#xff0c;也能提升品牌影响力并吸引潜在客户。许多服务器提供商&#xff08;如 Hostease&#xff09;支持 WordPress 一键安装功能&#xff0c;方便新手快速完成安装&#xff0c;专注于内容创作和 SEO 优化。然而&#xff0c;写出…

Python:操作 Excel 折叠

💖亲爱的技术爱好者们,热烈欢迎来到 Kant2048 的博客!我是 Thomas Kant,很开心能在CSDN上与你们相遇~💖 本博客的精华专栏: 【自动化测试】 【测试经验】 【人工智能】 【Python】 Python 操作 Excel 系列 读取单元格数据按行写入设置行高和列宽自动调整行高和列宽水平…

雨季智慧交通:从车辆盲区到客流统计的算法全覆盖

雨季智慧交通中的视觉分析技术应用 一、背景&#xff1a;雨季交通的复杂挑战 雨季是城市交通管理的关键考验期。以济南为例&#xff0c;强对流天气伴随的短时强降水、雷雨大风及冰雹&#xff0c;不仅导致道路积水、能见度骤降&#xff0c;还加剧了大型车辆&#xff08;如渣土…