React useRef Hook

useRef Hook 允许您在渲染之间保持值。

它可以用来存储一个在更新时不会导致重新渲染的可变值。

它可以用来直接访问一个DOM元素。


不会导致重新渲染

如果我们尝试使用 useState Hook 计算应用程序渲染的次数,我们将陷入无限循环,因为该 Hook 本身会导致重新渲染 .

为了避免这种情况,我们可以使用 useRef Hook。

实例:

使用 useRef 来跟踪应用程序渲染。

import { useState, useEffect, useRef } from "react";
import ReactDOM from "react-dom/client";

function App() {
  const [inputValue, setInputValue] = useState("");
  const count = useRef(0);

  useEffect(() => {
    count.current = count.current + 1;
  });

  return (
    <>
      <input
        type="text"
        value={inputValue}
        onChange={(e) => setInputValue(e.target.value)}
      />
      <h1>Render Count: {count.current}</h1>
    </>
  );
}

const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<App />);

运行实例 »

useRef() 只返回一项。 它返回一个名为 current 的对象。

当我们初始化 useRef 时,我们设置了初始值:useRef(0)

就像这样做:const count = {current: 0}。 我们可以使用 count.current 来访问计数。

在您的计算机上运行此程序并尝试输入输入以查看应用程序渲染计数增加。


访问 DOM 元素

一般来说,我们希望让 React 处理所有 DOM 操作。

但在某些情况下,可以使用 useRef 而不会引起问题。

在 React 中,我们可以为元素添加 ref 属性,以便直接在 DOM 中访问它。

实例:

使用 useRef 聚焦输入:

import { useRef } from "react";
import ReactDOM from "react-dom/client";

function App() {
  const inputElement = useRef();

  const focusInput = () => {
    inputElement.current.focus();
  };

  return (
    <>
      <input type="text" ref={inputElement} />
      <button onClick={focusInput}>Focus Input</button>
    </>
  );
}

const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<App />);

运行实例 »


跟踪状态变化

useRef Hook 也可用于跟踪之前的状态值。

这是因为我们能够在渲染之间保持 useRef 值。

实例:

使用 useRef 来跟踪之前的状态值:

import { useState, useEffect, useRef } from "react";
import ReactDOM from "react-dom/client";

function App() {
  const [inputValue, setInputValue] = useState("");
  const previousInputValue = useRef("");

  useEffect(() => {
    previousInputValue.current = inputValue;
  }, [inputValue]);

  return (
    <>
      <input
        type="text"
        value={inputValue}
        onChange={(e) => setInputValue(e.target.value)}
      />
      <h2>Current Value: {inputValue}</h2>
      <h2>Previous Value: {previousInputValue.current}</h2>
    </>
  );
}

const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<App />);

运行实例 »

这次我们使用 useStateuseEffectuseRef 来跟踪之前的状态。

useEffect 中,每次 inputValue 通过在输入字段中输入文本来更新。