• react,hooks中的useRef使用


    React中,useRef 是一个 Hook,它返回一个可变的引用对象,其 .current 属性被初始化为传递的参数(initialValue)。这个引用对象会在组件的整个生命周期内保持不变,并且可以在函数组件内部存储任何可变值,而不必触发重新渲染。

    以下是一个 useRef 的基本使用示例:

    import React, { useRef } from 'react';
    
    function TextInputWithFocusButton() {
      // 创建一个ref来获取input元素
      const inputEl = useRef(null);
    
      // 定义一个函数,用于将焦点设置到input元素上
      const onButtonClick = () => {
        // 使用ref.current访问DOM元素
        inputEl.current.focus();
      };
    
      return (
        <div>
          {/* 将ref通过ref属性传递给元素 */}
          <input type="text" ref={inputEl} />
          
          {/* 当按钮被点击时,调用onButtonClick函数 */}
          <button onClick={onButtonClick}>Focus the input</button>
        </div>
      );
    }
    
    export default TextInputWithFocusButton;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24

    在这个例子中:

    我们首先导入了 useRef Hook。
    在组件内部,我们调用 useRef(null) 来创建一个引用对象 inputEl。
    然后定义了一个处理函数 onButtonClick,当点击按钮时,该函数会被调用,进而调用 inputEl.current.focus() 来将焦点设置到与 inputEl 关联的 元素上。
    在 标签上,我们将 inputEl 作为 ref 属性的值传入。React会自动将DOM元素关联到 inputEl.current 上,这样我们就可以在组件的任何地方直接访问和操作这个DOM元素了。
    除了获取和操作DOM元素之外,useRef 还可以用来保存任何需要跨渲染周期保持的值,例如滚动位置、计数器或者其他非响应式的变量。

  • 相关阅读:
    监控易:IT基础资源监控的解决方案和价值
    [FSCTF 2023] web题解
    华为S5700交换机初始化和配置SSH和TELNET远程登录方法
    多种方法查看Mysql版本信息(Windows、LINUX系统都适用)
    Linux进程状态
    时间计算器
    c语言从入门到实战——分支和循环
    哥德巴赫猜想
    【密码加密原则】
    项目实战 Java读取Excel数据
  • 原文地址:https://blog.csdn.net/weixin_45506717/article/details/136532149