React中useRef的使用

在 React 中,useRef 是一个钩子,用于返回一个可变的 ref 对象,其 .current 属性被初始化为传递的参数(initialValue)。这个返回的对象在组件的整个生命周期内保持不变。useRef 可以用来直接访问 DOM 元素或存储任何不会引起重新渲染的可变值。

以下是如何使用 useRef 访问 DOM 元素的示例:

示例:使用 useRef 访问 DOM 元素

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

function MyComponent() {
  const myDivRef = useRef(null);

  useEffect(() => {
    // 访问 DOM 元素
    if (myDivRef.current) {
      myDivRef.current.style.backgroundColor = 'lightblue';
    }
  }, []);

  return (
    <div ref={myDivRef}>
      这个 div 的背景颜色是通过 useRef 设置的。
    </div>
  );
}

export default MyComponent;

在这个例子中:

  1. 创建 Refconst myDivRef = useRef(null); 创建一个初始值为 null 的 ref 对象。
  2. 附加 Refref={myDivRef} 属性将 ref 附加到 <div> 元素上。
  3. 使用 Ref:在 useEffect 钩子中,myDivRef.current 允许你访问 div DOM 元素,从而可以直接操作它。

示例:使用 useRef 存储可变值

import React, { useRef } from 'react';

function Counter() {
  const countRef = useRef(0);

  const handleClick = () => {
    countRef.current += 1;
    console.log(`计数值现在是: ${countRef.current}`);
  };

  return (
    <div>
      <button onClick={handleClick}>增加计数</button>
    </div>
  );
}

export default Counter;

在这个例子中:

  1. 创建 Refconst countRef = useRef(0); 创建一个初始值为 0 的 ref 对象。
  2. 更新 RefhandleClick 函数更新 countRef.current 而不会引起重新渲染。

关键点

  • 持久性:ref 对象在重新渲染之间保持持久。
  • 无重新渲染:更新 ref 对象的 .current 属性不会引起组件重新渲染。
  • DOM 访问useRef 通常用于直接访问和操作 DOM 元素。

以上例子展示了如何在 React 中基本使用 useRef 来访问 DOM 元素和存储可变值。

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ArslanRobot

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值