首页 >web前端 >js教程 >如何在 React 中选择 DOM 元素:'document.getElementById()”的替代方案?

如何在 React 中选择 DOM 元素:'document.getElementById()”的替代方案?

DDD
DDD原创
2024-12-04 06:21:11640浏览

How to Select DOM Elements in React:  Alternatives to `document.getElementById()`?

如何在 React 中选择 DOM 元素? React 中 document.getElementById() 的等价物是什么

在 React 中,与使用普通 JavaScript 不同,直接访问 DOM 元素是不同的。 React 使用虚拟 DOM 来高效更新真实 DOM,这使得它与普通 JavaScript 不同。

如何访问 DOM 元素

选项 1:使用 Refs

  • 将 Ref 与函数一起使用组件:(v16.8.0) 使用useRef 和forwardRef。使用useRef 定义ref,然后使用forwardRef 将其转发到DOM 元素。要访问该元素,请使用 ref 的 current 属性 (ref.current)。

选项 2:使用 React.createRef (v16.3 )

  • 使用 React.createRef() 创建一个 ref 并将其附加到一个元素以便稍后访问它。使用 ref.current 获取 DOM 节点。

选项 3:使用回调模式(旧版)

  • 在 JSX 中定义 ref 属性元素并传递一个接收 DOM 引用的回调函数

选项 4:使用字符串引用(旧版)

  • 通过将 ref 属性设置为标识 DOM 元素的字符串来使用字符串引用。使用 this.refs.[stringRef].

示例

下面是使用回调模式选择 DOM 元素的示例:

  render() {
    return (
      <div>
        <Progressbar
          completed={25}
         >

要访问元素,可以使用 this.progressBars[0]、this.progressBars[1] 和this.progressBars[2] 对它们执行操作。

以上是如何在 React 中选择 DOM 元素:'document.getElementById()”的替代方案?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn