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 元素。

相关推荐
CoolerWu5 小时前
TRAE SOLO实战成功展示&总结:一个所见即所得的笔记软体
前端·javascript
Cassie燁5 小时前
el-button源码解读1——为什么组件最外层套的是Vue内置组件Component
前端·vue.js
vx_bscxy3225 小时前
告别毕设焦虑!Python 爬虫 + Java 系统 + 数据大屏,含详细开发文档 基于web的图书管理系统74010 (上万套实战教程,赠送源码)
java·前端·课程设计
北极糊的狐5 小时前
Vue3 子组件修改父组件传递的对象并同步的方法汇总
前端·javascript·vue.js
spionbo5 小时前
Vue3 前端分页功能实现的技术方案及应用实例解析
前端
Zyx20075 小时前
JavaScript 作用域与闭包(下):闭包如何让变量“长生不老”
javascript
AI绘画小335 小时前
Web 安全核心真相:别太相信任何人!40 个漏洞挖掘实战清单,直接套用!
前端·数据库·测试工具·安全·web安全·网络安全·黑客
7***n755 小时前
前端设计模式详解
前端·设计模式·状态模式
u***j3245 小时前
JavaScript在Node.js中的进程管理
开发语言·javascript·node.js
用户47949283569155 小时前
Vite 中 SVG 404 的幕后黑手:你真的懂静态资源处理吗?
前端·vite