React hooks - useRef

useRef

用法

useRef 函数返回一个可变的 ref 对象,该对象只有一个 current 属性。可以在调用 useRef 函数时为其指定初始值。并且这个返回的 ref 对象在组件的整个生命周期内保持不变。

javascript 复制代码
// 1. 导入 useRef
import { useRef } from 'react'
// 2. 调用 useRef 创建 ref 对象
const refObj = useRef(初始值)
// 3. 通过 ref.current 访问 ref 中存储的值
console.log(refObj.current)
特点
  1. 获取 DOM 元素或子组件的实例对象
javascript 复制代码
import React, { useRef } from 'react'

export const InputFocus: React.FC = () => {
  // 1. 创建 ref 引用
  const iptRef = useRef<HTMLInputElement>(null) // 加上泛型引用后就可以提示代码了

  const getFocus = () => {
    // 3. 调用 focus API,让文本框获取焦点
    iptRef.current?.focus() // iptRef.current可能为空,后面使用链式调用?.来保证不报错
  }

  return (
    <>
      {/* 2. 绑定 ref 引用 */}
      <input type="text" ref={iptRef} />
      <button onClick={getFocus}>点击获取焦点</button>
    </>
  )
}
  1. 存储渲染周期之间共享的数据
javascript 复制代码
export const Counter: React.FC = () => {
  const [count, setCount] = useState(0)
  const prevCountRef = useRef<number>() // 默认值为 undefined,泛型为number,将来要存number类型的值
  let preCount // 创建一个变量存储旧值无法实现,因为每次count发生变化时组件重新渲染导致preCount初始化为undefined
  const add = () => {
    setCount((c) => c + 1)
    prevCountRef.current = count // 记录旧值到prevCountRef中
    // preCount = count // 错误写法,无法实现
  }
  return (
    <>
      <h1>新值是:{count},旧值是:{prevCountRef.current} </h1>
      <button onClick={add}>+1</button>
    </>
  )
}
注意事项
  1. 组件rerender(重新渲染)时useRef不会被重复初始化
  2. ref.current发生变化时不会造成组件的rerender(重新渲染)
  3. ref.current不能作为其他hooks(useMemo、useCallback、useEffect 等) 的依赖项
    组件首次渲染后会触发一次 useEffect 。但当time.current 变化不会触发 useEffect 的重新执行。
javascript 复制代码
export const RefTimer: React.FC = () => {
  const time = useRef(Date.now())
  const updateTime = () => {
    time.current = Date.now()
  }
  useEffect(() => {
    console.log('time 的值发生了变化:' + time.current)
  }, [time.current])

  return (
    <>
      <h3>时间戳是:{time.current}</h3>
      <button onClick={updateTime}>给ref赋新值</button>
    </>
  )
}
相关推荐
我命由我123451 小时前
React - BrowserRouter 与 HashRouter、push 模式与 replace 模式、编程式导航、withRouter
开发语言·前端·javascript·react.js·前端框架·html·ecmascript
哈__3 小时前
ReactNative项目OpenHarmony三方库集成实战:lottie-react-native
javascript·react native·react.js
我命由我123455 小时前
React - React 配置代理、搜索案例(Fetch + PubSub)、React 路由基本使用、NavLink
开发语言·前端·javascript·react.js·前端框架·html·ecmascript
周淳APP5 小时前
【React Fiber架构+React18知识点+浏览器原生帧流程和React阶段流程相串】
前端·javascript·react.js·架构
Csvn6 小时前
React 性能优化(上):memo 与 useMemo 的正确使用
react.js
console.log('npc')6 小时前
在 React 中,useRef、ref 属性以及 forwardRef 是处理“引用”(访问 DOM 节点或组件实例)的核心概念
前端·react.js·前端框架
张元清7 小时前
Pareto 3.0 发布:基于 Vite 7 的轻量级 React SSR 框架
前端·react.js
小时前端7 小时前
react状态管理:踩坑无数后,我为什么选择了 Zustand?
前端·react.js
哈__9 小时前
ReactNative项目OpenHarmony三方库集成实战:react-native-chart-kit
javascript·react native·react.js