查看 hooks 文档和一些博客我们了解到,在使用 useRef() 时,我们存储了一个可变值。
文档:
您可能熟悉 refs 主要是作为访问 DOM 的一种方式。如果您将 ref 对象传递给 React with ,React 会在该节点发生更改时将其 .current 属性设置为相应的 DOM 节点。
但是, useRef() 不仅仅用于 ref 属性。保持任何可变值类似于您在类中使用实例字段的方式,这很方便。
这是有效的,因为 useRef() 创建了一个普通的 JavaScript 对象。useRef() 和自己创建一个 {current: ...} 对象之间的唯一区别是 useRef 将在每次渲染时为您提供相同的 ref 对象。
与仅声明和使用变量相比,这给我们带来了哪些优势let
?
代码示例:
import React, {useRef} from "react";
const MyFunctionalComponent = (props) => {
const refVariable = useRef('value');
//versus
let letVariable = 'value';
}
跟进:给出的答案很有帮助,结合一些测试让我得到了我需要的理解。如果有人遇到这个概念有问题,我现在理解的方式是:
- 您可以拥有实例变量,但它们确实是即时的,并且每次重新渲染都会重新初始化它们。
- useRef() 给你一些更持久的东西,比如 useState() 但更新不会触发重新渲染,如果你以链接方式进行大量操作,非常有用,但不想触发重新渲染,直到结束
- useState() 应该只与 UI 元素使用的变量相关联,因为对状态的任何更改都会触发整个组件的重新渲染。在整个过程中不要有一连串操作状态的动作,使用 refs 直到链条的末端。