梳理一下react Hooks

devtools/2024/9/25 7:25:59/

本文引用React官网资料,地址:https://zh-hans.react.dev/reference/react/hooks(一是作者可以书写文章增加印象,二是好好学习学习官网的写法)
React 内置 Hook
Hook 可以帮助在组件中使用不同的 React 功能。你可以使用内置的 Hook 或使用自定义 Hook。本页列出了 React 中所有内置 Hook。

1、Effect Hook
Effect 允许组件 连接到外部系统并与之同步。这包括处理网络、DOM、动画、使用不同 UI 库编写的小部件以及其他非 React 代码。
使用 useEffect 将组件连接到外部系统。

function ChatRoom({ roomId }) {useEffect(() => {const connection = createConnection(roomId);connection.connect();return () => connection.disconnect();}, [roomId]);// ...

Effect 是从 React 范式中的“脱围机制”。避免使用 Effect 协调应用程序的数据流。如果不需要与外部系统交互,那么 可能不需要 Effect。

useEffect 有两个很少使用的变换形式,它们在执行时机有所不同:

useLayoutEffect 在浏览器重新绘制屏幕前执行,可以在此处测量布局。
useInsertionEffect 在 React 对 DOM 进行更改之前触发,库可以在此处插入动态 CSS。

2、Ref Hook
ref 允许组件 保存一些不用于渲染的信息,比如 DOM 节点或 timeout ID。与状态不同,更新 ref 不会重新渲染组件。ref 是从 React 范例中的“脱围机制”。当需要与非 React 系统如浏览器内置 API 一同工作时,ref 将会非常有用。

使用 useRef 声明 ref。你可以在其中保存任何值,但最常用于保存 DOM 节点。
使用 useImperativeHandle 自定义从组件中暴露的 ref,但是很少使用。

function Form() {const inputRef = useRef(null);// ...

3、Context Hook
上下文帮助组件 从祖先组件接收信息,而无需将其作为 props 传递。例如,应用程序的顶层组件可以借助上下文将 UI 主题传递给所有下方的组件,无论这些组件层级有多深。

使用 useContext 读取订阅上下文。

function Button() {const theme = useContext(ThemeContext);// ...

4、State Hook
状态帮助组件 “记住”用户输入的信息。例如,一个表单组件可以使用状态存储输入值,而一个图像库组件可以使用状态存储所选的图像索引。

使用以下 Hook 以向组件添加状态:

使用 useState 声明可以直接更新的状态变量。
使用 useReducer 在 reducer 函数 中声明带有更新逻辑的 state 变量。

function ImageGallery() {const [index, setIndex] = useState(0);// ...

性能 Hook
优化重新渲染性能的一种常见方法是跳过不必要的工作。例如,可以告诉 React 重用缓存的计算结果,或者如果数据自上次渲染以来没有更改,则跳过重新渲染。

可以使用以下 Hook 跳过计算和不必要的重新渲染:

使用 useMemo 缓存计算代价昂贵的计算结果。
使用 useCallback 将函数传递给优化组件之前缓存函数定义。

function TodoList({ todos, tab, theme }) {const visibleTodos = useMemo(() => filterTodos(todos, tab), [todos, tab]);// ...
}

有时由于屏幕确实需要更新,无法跳过重新渲染。在这种情况下,可以通过将必须同步的阻塞更新(比如使用输入法输入内容)与不需要阻塞用户界面的非阻塞更新(比如更新图表)分离以提高性能。

使用以下 Hook 处理渲染优先级:

  • useTransition 允许将状态转换标记为非阻塞,并允许其他更新中断它。
  • useDeferredValue 允许延迟更新 UI 的非关键部分,以让其他部分先更新。

http://www.ppmy.cn/devtools/98708.html

相关文章

【LLM之Base Model】Weaver论文阅读笔记

研究背景 当前的大型语言模型(LLM)如GPT-4等,尽管在普通文本生成中表现出色,但在创造性写作如小说、社交媒体内容等方面,往往不能很好地模仿人类的写作风格。这些模型在训练和对齐阶段,往往使用的是大规模…

招聘谈薪教训

以前觉得是招聘段子,知道实习后才发现句句真理,这里每一点一不留神全是大坑: 1.薪资结构,底薪多少 2.工资是下个月几号发,碰到当月工资当月发的绝对良心企业,下个月15号之前发的还能接受,15号…

人格凭证(PHC):一种鉴别AI防伪保护隐私的真实身份验证技术

人格凭证(PHC):一种鉴别AI防伪保护隐私的真实身份验证技术 引言 随着人工智能(AI)技术的飞速发展,网络空间中的身份验证问题日益凸显。AI不仅能模仿人类行为,还能创建虚假账户、发布误导性信息…

DMDSC搭建

DMDSC搭建 DMDSC 集群是一个多实例、单数据库的系统。多个数据库实例可以同时访问、修改同一个数据库的数据。用户可以登录集群中的任意一个数据库实例,获得完整的数据库服务。 ​ 本文开始进行DMDSC集群的搭建学习。 环境配置 虚拟机配置 参数详情 设备摘要内存…

Prometheus 服务发现

1、基于文件的服务发现 基于文件的服务发现是仅仅略优于静态配置的服务发现方式,它不依赖于任何平台或第三方服务,因而也是最为简单和通用的实现方式。 Prometheus Server 会定期从文件中加载 Target 信息,文件可使用 YAML 和 JSON 格式&…

SpringBoot优雅的封装不同研发环境下(环境隔离)RocketMq自动ack和手动ack

1. RocketMq的maven依赖版本&#xff1a; <dependency><groupId>org.apache.rocketmq</groupId><artifactId>rocketmq-spring-boot-starter</artifactId><version>2.3.0</version></dependency>2.RocketMq的yml文件&#xff1…

Unity+Addressable

前期准备 下载一个hfs本地服务器&#xff0c;打开即可 HFS ~ HTTP 文件服务器 (rejetto.com) 1.安装Addressable插件 创建组 2.使用图片创建预制体 放入Addressable Groups内 3.右键 新建组 创建预制体t拖拽放入新建组里 新组命名为Gameobject 简化名称 4.创建一个测试脚本 …

【git bash编码错误解决方案】启动conda环境时报错,其他terminal却正常

&#x1f50e;嘿&#xff0c;这里是慰慰&#x1f469;&#x1f3fb;‍&#x1f393;&#xff0c;会发各种类型的文章&#xff0c;智能专业&#xff0c;从事前端&#x1f43e; &#x1f389;如果有帮助的话&#xff0c;就点个赞叭&#xff0c;让我开心一下&#xff01;&#x1f…