当前位置: 首页 > article >正文

react 中 useRef Hook 作用

`useRef`是一个非常实用的钩子函数

一、访问和操作 DOM 元素

1. 获取 DOM 元素引用

1.1 基本原理

通过 `useRef` 我们可以直接操作 DOM 元素

1.2 代码示例

import React, { useRef, useEffect } from "react";



const InputFocusComponent = () => {

  const inputRef = useRef(null);



  useEffect(() => {

    // 组件挂载后,使输入框获得焦点

    if (inputRef.current) {

      inputRef.current.focus();

    }

  }, []);



  return (

    <div>

      <input type="text" ref={inputRef} />

    </div>

  );

};



export default InputFocusComponent;

2. 跨渲染周期保持引用

2.1 渲染周期中的稳定性

例如:在一个定时器的场景中,需要在组件挂载时启动定时器,并在组件卸载时清除定时器,`useRef`可以帮助我们保持对定时器 ID 的引用。

2.2 代码示例

import React, { useRef, useEffect, useState } from "react";



const TimerComponent = () => {

  const timerRef = useRef(null);

  const [count, setCount] = useState(0);



  useEffect(() => {

    // 组件挂载时启动定时器

    timerRef.current = setInterval(() => {

      setCount((prevCount) => prevCount + 1);

    }, 1000);



    return () => {

      // 组件卸载时清除定时器

      if (timerRef.current) {

        clearInterval(timerRef.current);

      }

    };

  }, []);



  return (

    <div>

      <p>Seconds passed: {count}</p>

    </div>

  );

};



export default TimerComponent;

二、保存可变值

1. 避免重新渲染触发的问题

1.2 与 state 的区别

例如:在一个数据获取的场景中,获取数据时不需要触发组件渲染。

1.3 代码示例

import React, { useRef, useState, useEffect } from "react";



const DataFetchingComponent = () => {

  const isFetchingRef = useRef(false);

  const [data, setData] = useState(null);



  useEffect(() => {

    if (!isFetchingRef.current) {

      isFetchingRef.current = true;

      fetch("https://example.com/api/data")

        .then((response) => response.json())

        .then((jsonData) => {

          setData(jsonData);

          isFetchingRef.current = false;

        });

    }

  }, []);



  return (

    <div>

      {data ? (

        <pre>{JSON.stringify(data)}</pre>

      ) : (

        <p>

          {isFetchingRef.current ? "Fetching data..." : "No data available"}

        </p>

      )}

    </div>

  );

};



export default DataFetchingComponent;


http://www.kler.cn/a/398238.html

相关文章:

  • MCU的时钟体系
  • 有序数组的平方(leetcode 977)
  • Android OpenGL ES详解——实例化
  • 开源共建 | 长安链开发常见问题及规避
  • Linux从0——1之shell编程4
  • 【Linux庖丁解牛】—Linux基本指令(下)!
  • 机器学习—学习曲线
  • Vanna使用ollama分析本地MySQL数据库 加入redis保存训练记录
  • torch.stack 张量维度的变化
  • 记录大学Linux运维上机考试题目和流程
  • 使用Python实现对接Hadoop集群(通过Hive)并提供API接口
  • STM32F103移植FreeRTOS
  • Scala-字符串(拼接、printf格式化输出等)-用法详解
  • Spring Boot编程训练系统:开发与部署
  • SpringBoot 创建对象常见的几种方式
  • UEFI学习(五)——启动框架
  • web-02
  • DB-GPT系列(六):数据Agent开发part1-光速创建AWEL Agent应用
  • Java 全栈知识体系
  • Oracle Instant Client 23.5安装配置完整教程
  • django框架-settings.py文件的配置说明
  • 【C语言】前端未来
  • 公开一下我的「个人学习视频」!
  • 【系统架构设计师】真题论文: 论基于 REST 服务的 Web 应用系统设计(包括解题思路和素材)
  • SQL面试题——日期交叉问题
  • PMP–一、二、三模、冲刺–分类–5.范围管理–技巧–引导