React 函数组件导出自定义方法的办法说明

2023-05-16

在进行React开发时,函数组件是比较方便的,由于函数组件没有this指针,因此如果想在父组件里调用函数型子组件的方法,就需要用到React.useImperativeHandle 这个帮助函数。

办法要点:

1、在子组件中,使用useImperativeHandle函数将子组件中的方法暴露出去,在导出时使用forwardRef包裹导出的组件;

2、理解 useImperativeHandle 函数的两个参数:
        第一个参数ref即是函数组件自带的参数(props,ref)中的 ref。
        第二个参数是一个函数,函数返回的对象就是父组件中的 childRef.current

3、需要暴露方法的组件,在导出的时候,一定要加上forwardRef进行包裹

export default forwardRef(Son)

子组件示例: 

import React, { useState, forwardRef, useImperativeHandle } from "react"

function Son(props, ref) {
    const [a, setA] = useState(1);
    const [b, setB] = useState(2);

    function sonFunc() {
        console.log("我是儿子中的方法")
    }

    useImperativeHandle(ref, () => {
        return {
            sonFunc,
            setA,
            a: a,
            b
        }
    });

    return (
        <div id="headerBox">
            {a}
        </div>
    )
}

export default forwardRef(Son)

 4、在父组件中使用useRef(),并对子组件进行绑定 ref 。

        打印的childRef中有一个属性叫做currentcurrent就是子组件暴露出来的实例句柄。

        点击父亲的执行按钮,就可以通过childRef.current.sonFunc()执行子组件的方法sonFun,也可以执行儿子中的改变state的方法setA,从而通过父组件来改变子组件的状态值。

调用者(父组件)示例: 

import React, { useState, useRef} from "react";
import Son from "./Son";

function Father(props, ref) {
    const childRef = useRef(null);

    function printRef() {
        console.log(childRef );
    }
    function doSonFunc() {
        childRef.current.sonFunc();
        childRef.current.setA(456);//把子组件中的a从1改变为456
    }
    return (
        <div className="Home">
            <Son ref={childRef } />
            <button onClick={printRef}>打印ref</button>
            <button onClick={doSonFunc}>执行儿子的方法</button>
        </div>
    )
}

export default Father

这个方法不仅是可以用来调用儿子的方法,对于儿子的状态属性,也是能够传过来的。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

React 函数组件导出自定义方法的办法说明 的相关文章

  • 阿里巴巴开发手册最新版、码出高效、性能调优实战、成神之路

    清幽现云山 虚静出内功 阿里巴巴Java开发手册 是阿里内部Java工程师所遵循的开发规范 xff0c 涵盖编程规约 单元测试规约 异常日志规约 MySQL规约 工程规约 安全规约等 xff0c 这是近万名阿里Java技术精英的经验总结 x
  • ARM架构服务器安装docker

    我的服务器信息为 Linux ecs 1bc7 0001 4 19 90 17 5 ky10 aarch64 1 SMP Fri Aug 7 13 35 33 CST 2020 aarch64 aarch64 aarch64 GNU Lin
  • ARM服务器安装docker-compose

    我的服务器信息为 Linux ecs 1bc7 0001 4 19 90 17 5 ky10 aarch64 1 SMP Fri Aug 7 13 35 33 CST 2020 aarch64 aarch64 aarch64 GNU Lin
  • git删除已push的commit记录

    Git删除已经push的commit记录或者合并commit记录 问题 xff1a 1 commit注释写错 2 发版时 xff0c 只允许有一条commit记录 xff0c 但代码还push到远程了 3 没拉最新代码 xff0c 提交后合
  • Docker 基于centos构建nginx镜像 构建MySQL镜像

    第一题 基于centos镜像构建nginx xff1a 编写Dockerfile制作镜像 xff0c 生成镜像名为my build Nginx1 首先创建目录dockerfile nginx1 xff0c 保存Dockerfile文件 具体
  • 【HCIP-Datacom】 IS-IS基础 ISIS动态路由协议配置(ISIS思维导图在底部)

    目录 ISIS配置方法 xff1a 路由计算 xff1a ATT置位条件 xff1a 路由渗透 xff1a ISIS的认证 xff1a ISIS配置命令 xff1a ISIS的开销类型 xff1a ISIS配置方法 xff1a 进入ISIS
  • flutter main.dart': No such file or directory

    VSCode 的错误 修改箭头处涂改部分为项目名即可
  • C语言,实现字符串的排序【升序、降序都实现】【使用函数指针调用】

    实现字符串的排序 升序 降序都实现 使用函数指针调用 voidsort char str int n int flag 参数说明 arr接收实参数组 n接收数组长度 xff0c flag接收升降序 xff0c 如果为1则完成升序 xff0c
  • Debian搭建Squid服务

    实验拓扑 实验要求 Server01 IP地址 172 16 100 201 25 网关 172 16 100 254 Server02 IP地址 192 168 10 3 28 网关 192 168 10 2 Rserver IP地址 1
  • Debian搭建SSH服务

    SSH 安装SSH 仅允许client客户端进行ssh访问 xff0c 其余所有主机的请求都应该拒绝 xff1b 配置client只能在Chinaskill20用户环境下可以免秘钥登录 xff0c 端口号为2222 xff0c 并且拥有ro
  • Debian系统做磁盘阵列RAID5

    RAID5 在虚拟机上添加 4 个 1G 的硬盘 创建 raid5 其中一个作为热备盘 设备名为md0 将 md0 设置为 LVM 设备为 dev vg01 lv01 格式化为 ext4 文件系统 开机自动挂载到 data 目录 第一步 添
  • 利用冒泡法对10个数字进行排序

    将10个数由小到大进行排序 用冒泡法 第一趟比较 xff0c 如果是6个元素 xff0c 要进行n 1 xff0c 也就是6 1等于5次两两比较 第二趟比较中 xff0c 要进行n j xff08 j是趟数 xff09 两两比较 xff0c
  • Cloudreve添加腾讯云对象存储策略教程

    Cloudreve安装好后就可以添加存储策略了 xff0c 设置文件存储的位置 xff0c 我将文件存储在腾讯云对象存储 xff0c 使用内容分发进行下载加速和保护源站 对象存储和内容分发是收费的 xff0c 需要购买存储容量包 内容分发流
  • 汇编语言指令大全

    一 数据传输指令 它们在存贮器和寄存器 寄存器和输入输出端口之间传送数据 1 通用数据传送指令 MOV 传送字或字节 MOVSX 先符号扩展 再传送 MOVZX 先零扩展 再传送 PUSH 把字压入堆栈 POP 把字弹出堆栈 PUSHA 把
  • Access-Control-Allow-Origin跨域解决及详细介绍

    首先 xff0c 跨域不是问题 是一种安全机制 这是你在开发时 上线前就必须提前考虑到的安全问题并且采取合适的手段去避免这个问题带来的程序错误 不过通常情况下 xff0c 前端开发的小伙伴们都非常坚信后端小伙伴的接口一定已经处理好了跨域这个
  • CCF-CSP历年真题大全附题解(202303已更)

    CCF CSP真题拿来练手 xff0c 持续更新 xff0c CCF CSP真题拿来练手 xff0c 如果对自己没有拿高分的期望的话 xff0c 可以就琢磨着写一二三题就好 xff0c 三题和四题可以稍微瞧一瞧 xff0c 可以就拿最基础的
  • Notepad ++ 安装与配置

    目录 Notepad 43 43 获取与安装 Notepad 43 43 是什么 获取 Notepad 43 43 安装包 安装 Notepad 43 43 可以很方便的转换编码 配置 Notepad 43 43 首选项 常用 编辑 暗黑模
  • 在Docker中安装并修改MySQL中的 my.cnf 配置文件

    前言 前期经过MySQL主从复制之后 xff0c 发现数据库的读写非常慢 xff0c 而且经常发生MySQL连接数过小 xff0c 导致整个数据库崩溃的情况 通过修改MySQL中的 my cnf 配置文件参数 xff0c 以达到MySQL关
  • Armbian 笔记一_初次登陆配置 Armbian 系统

    目录 初次登陆配置 arm 系统 参考链接和当前场景 初次登陆配置 root 密码 默认终端 普通用户 无线网络 时间和地区设置 关闭系统 初次登陆配置 arm 系统 参考链接和当前场景 参考燃吹哥哥的这篇博客 真的炒鸡详细 xff1a 猿
  • Armbian 笔记五_如何在 Armbian 上安装 xfce4 桌面

    目录 使用 armbian software 选择 Desktop 安装 xfce4 桌面 准备工作 正常开机 必须存在着一个普通用户 连接有线网络 下载安装设置 armbian software 201 是 Desktop 输入普通用户

随机推荐

  • 二维数组中的查找(杨氏矩阵(C语言+Java))

    二维数组中的查找这道题 xff0c 出自 剑指Offer 也是著名的杨氏矩阵 在一个 n m 的二维数组中 xff0c 每一行都按照从左到右递增的顺序排序 xff0c 每一列都按照从上到下递增的 输入一个数 xff0c 判断矩阵中是否存在这
  • 【操作系统实验】Ubuntu Linux 虚拟机目录文件操作

    文章目录 目录的创建和删除创建目录删除目录 文件的创建和删除创建文件删除文件 复制目录 文件移动目录 文件 目录的创建和删除 创建目录 mkdir 命令 功能描述 xff1a mkdir命令用来创建指定名称的目录 要求创建目录的用户在当前目
  • mysql-8.0.30最新密码重置方法,看这一篇就够了

    博主自己多次忘记自己本地MySQL的密码 xff0c 多次 删库跑路 xff0c 现写下这篇技术贴 xff0c 一来是为后续网友们遇到相同问题可以少走弯路 xff0c 二来是给自己做一个备忘录 之前查阅了很多关于更改MySQL密码的方式是在
  • Centos7安装OpenStack Rocky版本和openstack基本使用

    文章目录 环境 xff1a 设置主机名验证配置域名和IP映射关闭防火墙和SeLinux时间同步配置OpenStack rocky的yum源文件安装centos release openstack rocky安装openstack客户端安装数
  • 详解%d、%%d、%%%d和\\%d的区别

    1 d xff0c 表示按整型输出后面给出的变量的值 2 d xff0c 这就会被拆成两部分看待 xff0c 一是 在C语言中就是输出一个 xff0c 而是 d 就是一个普通字符 xff0c 所以当 d 在一起时 xff0c 其含义就是输出
  • C语言数组小记1

    在一维数值里 xff1a xff08 假设a 0 的地址为2000 xff09 如 xff1a int a 61 10 9 8 7 6 5 xff1b printf xff08 d d d xff0c a xff0c a 0 xff0c a
  • C语言数组小记2

    示例 xff1a 在二维数组下行与列的问题 如 xff1a int a 3 3 61 9 8 7 6 5 4 3 2 1 假设我们a 0 0 的地址是2000 xff0c a 0 1 的地址是2004 xff0c 相差4个字节 printf
  • 正点stm32串口中断理解

    首先把程序放上来 xff0c 最后结论总结在最后 u8 USART RX BUF USART REC LEN u16 USART RX STA 61 0 void USART1 IRQHandler void 串口1中断服务程序 u8 Re
  • windows用xrdp方式远程桌面连接ubuntu

    windows系统 xff1a win10 ubuntu系统 xff1a 18 04 5 参考文章 xff1a https forum ubuntu org cn viewtopic php f 61 54 amp p 61 3221658
  • Linux中用vim编辑器打开时自动补入头文件,注释方法

    1 首先我用的是乌班头的linux xff0c 打开终端 2 通常我们打开终端的时候是直接在home目录下3 我们直接直接退到根目录下 xff0c 找到etc目录 4 输入sudo vi etc vim vimrc 其实熟练的也可以234步
  • HTTP中get、post、put、delete的区别

    今天开发遇到了 put请求 xff0c 顺便过来拔拔草 xff01 先说说最常用的get请求跟post请求的区别 xff1a GET请求 xff1a 一般是获取服务器资源 xff1b get请求的查询参数需要挂载请求地址中 xff1b 请求
  • ubuntu网络无法连接(桥接模式)

    ubuntu桥接模式网络无法连接 问题描述 问题描述 最近几天遇到了一个网络配置问题 xff0c 因为之前的虚拟机崩了 xff0c 我就跟换了ubuntu21 04版本 xff0c 创建虚拟机的时候就选了桥接模式 xff0c 虚拟网络编辑器
  • centos7安装Prometheus+Grafana步骤

    sentos7安装Prometheus 43 Grafana 环境部署规划表 服务端 监视器 Prometheus服务端 Grafana服务端CentOS 7 9grafana192 168 3 230客户端 被监控主机 CentOS 7
  • gitlab-ce安装

    gitlab ce安装 sentos 下载 wget http mirrors tuna tsinghua edu cn gitlab ce yum el7 gitlab ce 12 9 0 ce 0 el7 x86 64 rpm 2021
  • gitlab-runner升级

    gitlab runner版本升级 添加GitLab官方仓库 For Debian Ubuntu Mint curl L https packages gitlab com install repositories runner gitla
  • docker可视化工具Shipyard

    Docker Shipyard Shipyard简介 shipyard是一个开源的docker管理平台 xff0c 其特性主要包括 xff1a 支持节点动态集群 xff0c 可扩展节点的规模 xff08 swarm etcd方案 xff09
  • jira8安装

    Jira8 3 3安装 下载jira安装包 xff0c 破解包和jdk包 链接 xff1a https pan baidu com s 1yHsXkW1ZpkcNQeBkvE Hog 提取码 xff1a zzzz 安装数据库 网上很多就不在
  • goteleport10.0本地安装使用

    goteleport10 0本地安装使用 环境说明 master xff1a 192 168 8 132 node1 xff1a 192 168 8 131 node2 xff1a 192 168 8 133 master本地生成域名证书
  • [csp2019]Emiya家今天的饭

    作为提高组 d 2 t 1 d2t1 d 2 t 1 xff0c 比去年难 所以这道题我打的特别的差 32pts 这道题我们很显然可以看到可以打一个暴力 复杂度
  • React 函数组件导出自定义方法的办法说明

    在进行React开发时 xff0c 函数组件是比较方便的 xff0c 由于函数组件没有this指针 xff0c 因此如果想在父组件里调用函数型子组件的方法 xff0c 就需要用到React useImperativeHandle 这个帮助函