详解React中如何获取真实的dom

 更新时间:2025年02月13日 10:08:56   作者:逆袭的菜鸟X  
这篇文章主要为大家详细介绍了React中获取真实的dom的相关方法,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下

在 React 中,获取真实的 DOM 元素通常通过 ref 来实现。ref 是一个特殊的属性,用于引用组件或 DOM 元素的实例。你可以通过 ref 获取到组件的真实 DOM 元素或组件实例。

1. 函数组件中的 useRef

在函数组件中,获取 DOM 元素的引用需要使用 useRef 钩子。

示例:函数组件中的 useRef 用法

import React, { useRef } from 'react';

function MyComponent() {
  // 创建一个 ref 来引用 DOM 元素
  const inputRef = useRef(null);

  const focusInput = () => {
    // 通过 ref 访问真实的 DOM 元素,并给它添加焦点
    inputRef.current.focus();
  };

  return (
    <div>
      <input ref={inputRef} type="text" />
      <button onClick={focusInput}>Focus the input</button>
    </div>
  );
}

export default MyComponent;

解释:

useRef 返回一个包含 .current 属性的对象,current 可以指向真实的 DOM 元素(或者组件实例,具体取决于 ref 的用途)。

在这个例子中,inputRef.current 会指向 <input> 元素本身,你可以通过它访问 DOM 元素的属性和方法(例如 focus())。

2. 类组件中的 createRef

在类组件中,获取 DOM 元素的引用需要使用 React.createRef() 方法。

示例:类组件中的 createRef 用法

import React, { Component } from 'react';

class MyComponent extends Component {
  // 在类组件中创建 ref
  constructor(props) {
    super(props);
    this.inputRef = React.createRef();
  }

  focusInput = () => {
    // 通过 ref 访问真实的 DOM 元素,并给它添加焦点
    this.inputRef.current.focus();
  };

  render() {
    return (
      <div>
        <input ref={this.inputRef} type="text" />
        <button onClick={this.focusInput}>Focus the input</button>
      </div>
    );
  }
}

export default MyComponent;

解释:

React.createRef() 用于在类组件中创建一个 ref 对象,this.inputRef.current 指向 DOM 元素(在此例中是 <input> 元素)。

focusInput 方法通过 this.inputRef.current.focus() 调用 DOM 方法来聚焦输入框。

3. 访问 DOM 元素的常见用途

获取输入框的值:你可以通过 ref 获取到输入框的值,虽然在大多数情况下,React 推荐使用受控组件来管理输入框的值,但有时直接访问 DOM 元素可能更简单。

示例:

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

  const handleSubmit = () => {
    alert(`Input value: ${inputRef.current.value}`);
  };

  return (
    <div>
      <input ref={inputRef} type="text" />
      <button onClick={handleSubmit}>Submit</button>
    </div>
  );
}

控制焦点:ref 可以用来控制元素的焦点(如前面的例子),让用户能够交互时快速导航到特定的输入框。

DOM 操作:你还可以直接操作 DOM 元素的其他属性,如添加事件监听器、获取元素尺寸、滚动等。

4. 使用 ref 获取自定义组件的实例

除了 DOM 元素,ref 还可以用来获取类组件的实例。

示例:获取类组件实例

import React, { Component } from 'react';

class MyButton extends Component {
  clickHandler() {
    alert('Button clicked!');
  }

  render() {
    return <button onClick={this.clickHandler}>Click Me</button>;
  }
}

class ParentComponent extends Component {
  constructor(props) {
    super(props);
    this.buttonRef = React.createRef();
  }

  triggerButtonClick = () => {
    this.buttonRef.current.clickHandler(); // 调用子组件的方法
  };

  render() {
    return (
      <div>
        <MyButton ref={this.buttonRef} />
        <button onClick={this.triggerButtonClick}>Trigger Child Button Click</button>
      </div>
    );
  }
}

export default ParentComponent;

解释:

this.buttonRef.current 会指向子组件 MyButton 的实例,因此你可以直接调用它的方法(如 clickHandler())。

ref 对于类组件和函数组件的使用方式略有不同,但它们的核心思想相同:通过 ref 获取实例或 DOM 元素的引用。

5. 注意事项

避免过度使用 ref:在 React 中,ref 是一种“逃逸机制”,它绕过了 React 的数据流和状态管理。尽量避免在没有必要的情况下使用 ref,推荐使用 React 的状态和 props 来管理数据和交互。

ref 只在渲染完成后有效:ref 只能在组件渲染完成后访问到 DOM 元素。因此,在 componentDidMount 或 useEffect 中使用 ref 时,要确保渲染已经完成。

6.总结

在 函数组件 中,使用 useRef 来获取真实的 DOM 元素。

在 类组件 中,使用 React.createRef() 来获取真实的 DOM 元素。

ref 用于访问 DOM 元素或组件实例,可以用于获取值、控制焦点或执行其他 DOM 操作。

到此这篇关于详解React中如何获取真实的dom的文章就介绍到这了,更多相关React获取真实dom内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • React 小技巧教你如何摆脱hooks依赖烦恼

    React 小技巧教你如何摆脱hooks依赖烦恼

    Hooks 是一种函数,该函数允许您从函数式组件 “勾住(hook into)” React 状态和生命周期功能。 Hooks 在类内部不起作用 - 它们允许你无需类就使用 React,本文带领大家学习React 小技巧教你如何摆脱hooks依赖烦恼,感兴趣的朋友一起看看吧
    2021-05-05
  • react diff 算法实现思路及原理解析

    react diff 算法实现思路及原理解析

    这篇文章主要介绍了react diff 算法实现思路及原理解析,本节我们正式进入基本面试必考的核心地带 -- diff 算法,了解如何优化和复用 dom 操作的,还有我们常见的 key 的作用,需要的朋友可以参考下
    2022-05-05
  • React避免不必要的重新渲染的方法示例

    React避免不必要的重新渲染的方法示例

    构建高性能 React 应用程序的关键之一是避免不必要的重新渲染,React 的渲染引擎是高效的,但防止在不需要的地方重新渲染仍然至关重要,在这篇文章中,我们将介绍常见错误以及如何避免它们,需要的朋友可以参考下
    2024-10-10
  • React Native全面屏状态栏和底部导航栏适配教程详细讲解

    React Native全面屏状态栏和底部导航栏适配教程详细讲解

    最近在写 React Native 项目,调试应用时发现顶部状态栏和底部全面屏手势指示条区域不是透明的,看起来很难受。研究了一下这个问题,现在总结一下解决方案,这篇文章主要介绍了React Native全面屏状态栏和底部导航栏适配教程
    2023-01-01
  • React Hooks中 useRef和useImperativeHandle的使用方式

    React Hooks中 useRef和useImperativeHandle的使用方式

    这篇文章主要介绍了React Hooks中 useRef和useImperativeHandle的使用方式,文中说明了useRef和useCallback一起使用, 可以解决闭包陷阱的问题,本文结合实例代码介绍的非常详细,需要的朋友可以参考下
    2023-10-10
  • 浅谈react useEffect闭包的坑

    浅谈react useEffect闭包的坑

    笔者最近用react useEffect闭包,其中踩到了一些坑在此与大家分享一下。需要的朋友们下面随着小编来一起学习学习吧
    2021-06-06
  • react为什么不推荐使用index作为key

    react为什么不推荐使用index作为key

    本文主要介绍了react为什么不推荐使用index作为key,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • React实现父组件调用子组件的两种写法

    React实现父组件调用子组件的两种写法

    react通信分很多种,比如:父子通信,兄弟通信等等,这里我们就简单说一下父子通信,父子通信分为:父组件调用子组件里面的方法;子组件调用子组件里面的方法,这里我们着重说一下父组件调用子组件,需要的朋友可以参考下
    2024-04-04
  • 关于react-router中的Prompt组件使用心得

    关于react-router中的Prompt组件使用心得

    这篇文章主要介绍了关于react-router中的Prompt组件学习心得,Prompt组件作用是,在用户准备离开该页面时, 弹出提示, 返回true或者false, 如果为true, 则离开页面, 如果为false, 则停留在该页面,本文结合示例代码介绍的非常详细,需要的朋友可以参考下
    2023-01-01
  • React+Node.js实现大文件传输与断点续传

    React+Node.js实现大文件传输与断点续传

    这篇文章主要为大家详细介绍了如何使用React前端和Node.js后端实现大文件传输和断点续传的功能,文中的示例代码讲解详细,感兴趣的小伙伴可以参考下
    2024-12-12

最新评论