• React_Refs转发


    1. 简介

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

    1.1 使用普通ref引用

    • 定义FancyButton
    FancyButton/index.js
    
    export default class FancyButton extends Component {
        render() {
            return (
                
            )
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 引用该组件
    import FancyButton from '../../components/FancyButton'
    const ref = React.createRef()
    async componentDidMount() {
    	console.log(ref.current, 'ref能获取到什么内容')
    }
    提交 Button
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

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

    1.2 使用React.forwardRef引用

    • 定义FancyButton
    import React from 'react'
    
    const FancyButton = React.forwardRef((props, ref) => (
        
    ))
    
    export default FancyButton
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 引用该组件方式同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,你无须超越谁,只要超越昨天的自己就好~

  • 相关阅读:
    Envoy熔断限流实践(一)基于Rainbond插件实现熔断
    2022最新Web前端经典面试试题及答案-史上最全前端面试题(含答案)
    CSS - 常用属性和布局方式
    随手笔记(四十九)——GsonBuilder.setLenient()
    Oracle数据库开发者工具
    爬虫篇-如何下载selenium及其适配谷歌浏览器插件chromedriver(含chrome各版本及下载地址)
    Fastapi项目初体验20230919
    英语——分享篇——每日200词——1001-1200
    consul服务注册与发现、服务配置与刷新
    gitee-git使用文档总结
  • 原文地址:https://blog.csdn.net/weixin_44593720/article/details/127784737