React 直接操作 DOM

React 直接操作 DOM

一般而言,我们在 React 中使用虚拟 DOM 来操作 DOM,但是有些时候,我们需要直接操作 DOM。在 React 中,我们可以使用 useRef 这个 Hook 函数来获取 DOM 元素。分为以下两个步骤:

  1. 在组件中定义一个 ref,并通过 useRef Hook 创建一个 ref 对象,并将其赋值给组件的 ref 属性。
  2. 在组件中通过 ref.current 访问 ref 对象,获取 DOM 元素。
    以下是一个简单的例子,展示如何在 React 中直接操作 DOM:
js 复制代码
import { useRef } from 'react';

function App() {
  // 创建一个 ref 对象
  const inputRef = useRef(null);
  return (
    <div>
      {/* 绑定一个 ref 到 input 组件 */}
      <input ref={inputRef} />
      <button
        onClick={() => {
          // 通过 ref 对象获取输入框组件
          console.log(inputRef.current);
          console.dir(inputRef.current);
        }}
      >
        聚焦输入框
      </button>
    </div>
  );
}

export default App;

这个例子中,我们首先使用 useRef Hook 创建了一个名为 inputRef 的 ref 对象,并将其赋值给组件的 ref 属性。然后,在组件中,我们通过 ref.current 访问该 ref 对象,获取到 DOM 元素。最后,我们通过 ref.current 就可以获取到 DOM 元素。

需要注意的是,在 DOM 可用时,我们才能够使用 ref.current 访问 DOM 元素。因此,在组件渲染之前,我们无法获取到 DOM 元素。

相关推荐
天平2 小时前
油猴脚本创建webworker踩坑记录
前端·javascript·typescript
原则猫4 小时前
前端基础大厦
前端
陈随易5 小时前
编程语言级别的Skill市场,AI Agent 的未来形态
前端·后端·程序员
SoaringHeart6 小时前
Flutter进阶:基于 EasyRefresh 的下拉刷新封装 n_easy_refresh_mixin.dart
前端·flutter
IT_陈寒8 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
子兮曰8 小时前
Agency-Agents 深度解析:400+ AI 专家的"梦之队"如何重塑开发工作流
前端·后端·vibecoding
山河木马8 小时前
渲染管线-计算得到gl_Position(顶点着色器)之后续GPU流程
javascript·webgl·图形学
竹林8189 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
妙码生花9 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
Awu122710 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude