函数组价 hook--useRef

useRef

useRef允许创建一个对元素或值的可变引用,创建的初始值为传入的参数,它的返回值是一个ref对象,这个对象使用.current属性就是该数据的最新值。它通常用于直接访问和管理DOM元素,存储持久值,或处理不应触发重新渲染的值。

  • 返回一个可变的 ref 对象,该对象只有个current属性,初始值为传入的参数
  • 返回的 ref 对象在组件的整个生命周期内保持不变,useRef类似于类组件的this
  • 当更新useRef创建的值时并不会触发组件的重新渲染,这是与useState不同的地方
  • 更新useRef创建的值是副作用操作,所以一般写在useEffect 或事件处理函数里

语法和使用

js 复制代码
const refContainer = useRef(initialValue);

多个同名ref情况

当页面中多个相同的同名的ref,后者会覆盖前者,只会获取一个。代码示例如下:

js 复制代码
import {useRef} from 'react'

export default function App() {
  let test=useRef();
  let look=()=>{
    console.log(test.current);
  }
  return (
    <div>
      <p ref={test}>App组件</p> 
      <p ref={test}>test</p>
      <button onClick={look}>look</button>
    </div>
  )
}

访问DOM元素

使用useRef的一个最简单的情况就是在函数组件里面获取DOM对象的引用。可以使用useRef直接引用组件内的元素,而不是使用document.getElementById或其他DOM的API来查询。

案例:组件挂载后输入框自动聚焦

js 复制代码
import {useRef,useEffect} from 'react'

export default function App() {
  // 使用useRef直接引用组件内的元素
  let inputel=useRef();
  useEffect(()=>{
    console.log(inputel);
    // 聚焦输入元素
    inputel.current.focus();
  })
  return (
    <div>
      <p>App组件</p> 
      <input type="text" ref={inputel}/> 
    </div>
  )
}

通过useRef定义inputel变量,在input元素上定义ref={inputel},这样通过inputel.current就可以获取到inputDom 元素,然后调用下focus函数进行获取焦点。

存储之前的值

使用useRef存储一个跨渲染持久的值,但更新它不会触发重新渲染。一个组件的state可以在多次渲染之后依旧不变。但是state的问题在于一旦修改了它就会造成组件的重新渲染。如果需要保存一些数据,并希望这些数据在组件重新渲染时不会丢失,可以使用 useRef

js 复制代码
import { useEffect, useRef, useState } from 'react';
export default function App() {
  const count = useRef(0);
  const [msg, setMsg] = useState([])
  useEffect(() => {
    count.current = count.current + 1;
  });
  const changeHandle = () => {
    const arr = [...msg];
    arr.push(7)
    setMsg(arr);
  };
  return (
    <>
      <div>
        页面加载了 {count.current} 次。
      </div>
      <button onClick={changeHandle}>修改msg</button>
    </>
  )
}
相关推荐
im_AMBER3 小时前
React 12
前端·javascript·笔记·学习·react.js·前端框架
青咕咕4 小时前
REACT系列 3、性能优化
react.js
爱学习的马喽6 小时前
React钩子函数完全指南:从useState到useEffect的实战详解与场景剖析
前端·javascript·react.js
JamSlade6 小时前
SSO登录验证设计要点细节(以微软 Microsoft SSO为例) 基于react python
python·react.js·microsoft
全马必破三8 小时前
React的设计理念与核心特性
前端·react.js·前端框架
洞窝技术8 小时前
前端人必看的 node_modules 瘦身秘籍:从臃肿到轻盈,Umi 项目依赖优化实战
前端·vue.js·react.js
Asort8 小时前
React函数组件深度解析:从基础到最佳实践
前端·javascript·react.js
青咕咕9 小时前
REACT系列:1、React 中 render() 的目的
react.js
mingupup11 小时前
React(二):构建一个简单的聊天助手学到的React知识
react.js
浮游本尊11 小时前
React 18.x 学习计划 - 第六天:React路由和导航
前端·学习·react.js