React 中如何创建Refs

useRef

js 复制代码
import React, { useRef, useEffect } from "react";

function MyComponent() {
  const myRef = useRef(null); // 创建 Ref

  useEffect(() => {
    // 访问 DOM 元素
    myRef.current.focus();
  }, []);

  return <input type="text" ref={myRef} />;
}

export default MyComponent;

回调ref

你也可以在函数组件中使用回调 Refs。这种方式下,你会提供 一个函数,该函数会在组件挂载和卸载时分别被调用,并将 DOM 节点或 组件实例作为参数。

js 复制代码
import React, { useState, useEffect } from "react";


function MyComponent() {
  const [ref, setRef] = useState(null)

  useEffect(() => {
    if(ref){
        // 你现在可以访问 dom 节点或组件实例
    }
  }, [ref]);

  return <input type="text" ref={node => setRef(node)} />;
}

export default MyComponent;

这两种创建 Ref 的方式主要区别在于:

  • React.useRef() 创建的 Ref 更简洁,API 更一致,而且 Ref 的值在组件的整个生命周期中保持不变。
  • 回调 Refs 更灵活,它允许你在组件挂载和卸载时执行一些额外的逻辑。但 是,如果回调函数是在 render 方法中定义的,那么每次 render 时都 会创建一个新的函数实例,可能会导致一些性能问题。
  • 除非你有特殊需求,否则建议使用 React.useRef() 来创建 Ref。
相关推荐
用户69371750013841 小时前
Google 正在“收紧侧加载”:陌生 APK 安装或需等待 24 小时
android·前端
蓝帆傲亦1 小时前
Web 前端搜索文字高亮实现方法汇总
前端
用户69371750013841 小时前
Room 3.0:这次不是升级,是重来
android·前端·google
漫随流水3 小时前
旅游推荐系统(view.py)
前端·数据库·python·旅游
踩着两条虫4 小时前
VTJ.PRO 核心架构全公开!从设计稿到代码,揭秘AI智能体如何“听懂人话”
前端·vue.js·ai编程
jzlhll1235 小时前
kotlin Flow first() last()总结
开发语言·前端·kotlin
蓝冰凌6 小时前
Vue 3 中 defineExpose 的行为【defineExpose暴露ref变量】详解:自动解包、响应性与实际使用
前端·javascript·vue.js
奔跑的呱呱牛6 小时前
generate-route-vue基于文件系统的 Vue Router 动态路由生成工具
前端·javascript·vue.js
柳杉6 小时前
从动漫水面到赛博飞船:这位开发者的Three.js作品太惊艳了
前端·javascript·数据可视化