React_Refs转发
创始人
2024-04-05 18:09:06
0

1. 简介

Ref转发是一项将ref自动地通过组件传递到其一子组件的技巧。对于大多数应用中的组件来说,这通常不是必需的。但其对某些组件,尤其是可重用的组件库是很有用的。

1.1 使用普通ref引用

  • 定义FancyButton
FancyButton/index.jsexport default class FancyButton extends Component {render() {return ()}
}
  • 引用该组件
import FancyButton from '../../components/FancyButton'
const ref = React.createRef()
async componentDidMount() {console.log(ref.current, 'ref能获取到什么内容')
}
提交 Button

此时,根据log打印内容我们会发现,我们获取到的是FancyButton组件信息
在这里插入图片描述

1.2 使用React.forwardRef引用

  • 定义FancyButton
import React from 'react'const FancyButton = React.forwardRef((props, ref) => (
))export default FancyButton
  • 引用该组件方式同1.1

此时,根据log我们会发现,ref引用的是定义的button组件对应的DOM
在这里插入图片描述
使用该方法可以获取底层DoM节点button的ref,并在必要时访问,就像其直接使用DOM button一样。上述示例发生情况逐步解释:

  1. 我们通过调用React.createRef创建了一个React ref并将其赋值给ref变量
  2. 我们通过指定ref为JSX属性,将其向下传递给
  3. React传递refforwardRef内函数 (props, ref) => ...作为其第二个参数
  4. 我们向下转发该ref参数到
  5. 当ref挂载完成,ref.current将指向

注意: 第二个参数 ref 只在使用 React.forwardRef 定义组件时存在。常规函数和 class 组件不接收 ref 参数,且 props 中也不存在 ref。 Ref 转发不仅限于 DOM 组件,你也可以转发 refs 到 class 组件实例中。

1.3 不同

由于两个一个是返回的DOM结构,一个是组件形式,所以后续可操作情形也有所不同。获取DOM结构后,我们可以直接进行一些操作。如:
const btn = ref.current;
btn.style='color:red'

如果有用,点个赞呗~

总结用法,希望可以帮助到你,
我是Ably,你无须超越谁,只要超越昨天的自己就好~

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...
有效的括号 一、题目 给定一个只包括 '(',')','{','}'...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...