当前位置: 首页 > news >正文

React 使用ref属性调用子组件方法(也可以适用于父子传参)

注意:①需使用hooks函数组件        ②使用了antDesign组件库(可不用)

如何使用

父组件代码

import React, { useState, useRef, useEffect } from 'react';
import { Button } from 'antd';
import Child from './components/child';export default () => {const childRef = useRef();//使用ref调用子组件的方法const handleOpen = () => {childRef.current.showModal('Hello word');};return (<div><Button type="primary" onClick={handleOpen}>点我</Button><Child ref={childRef} /></div>);
};

子组件代码

import React, { useImperativeHandle, forwardRef, useState, useRef, useEffect } from 'react';
import { Modal } from 'antd';const ChildComponent = forwardRef((props, ref) => {const [isModalOpen, setIsModalOpen] = useState(false);const [data, setData] = useState('');//弹框打开const showModal = async (data) => {setIsModalOpen(true);setData(data);};//弹框确定const handleOk = async () => {setIsModalOpen(false);};//弹框取消const handleCancel = () => {setIsModalOpen(false);};// 通过第二个参数ref来控制暴露哪些方法useImperativeHandle(ref, () => ({showModal,}));return (<div><Modal title="子组件" width={800} open={isModalOpen} onOk={handleOk} onCancel={handleCancel}><div>{data}</div></Modal></div>);
});export default ChildComponent;

注:本人前端小白 ,如有不对的地方还请多多指教

http://www.lryc.cn/news/428717.html

相关文章:

  • Linux CentOS java JDK17
  • 迭代与递归
  • wo是如何克服编程学习中的挫折感的?
  • vue3基础ref,reactive,toRef ,toRefs 使用和理解
  • 【Python机器学习】NLP的部分实际应用
  • LLM 压缩之二: ShortGPT
  • EmguCV学习笔记 VB.Net 5.2 仿射变换
  • Fink初识
  • PyTorch的torchvision内置数据集使用,transform+pytorch联合使用
  • MT1619 (A/B/C对应18W/22W/25W)如何避免温度高、电磁干扰
  • Hadoop 的基本 shell 命令
  • HCIP-交换实验
  • Windows下线程的创建与使用(win32-API)
  • 华为OD机试(C卷,100分)- 游戏分组
  • centos7.9系统按cloudpods
  • android apk 加固后的地图加载异常及重新签名
  • 手把手搭建私人在线备份系统
  • 数据分析实操案例分享:如何对人事数据进行BI分析?
  • 谷粒商城实战笔记-228-商城业务-认证服务-自定义SpringSession完成子域session共享
  • Elasticsearch核心
  • Python.NET:打开Python与.NET世界互通的大门
  • uniapp - plugins的组件配置使用
  • Microsoft Edge WebView2 截图
  • [word] 复杂文本如何仅全选word中的表格 (简单跟做即可)
  • Aop切面编程
  • 目标检测 | yolov9 原理和介绍
  • 如何在不格式化的情况下解锁Android智能手机密码
  • ts语法、nvm的使用以及github访问速度
  • 缓存实现方式
  • 鸿蒙内核源码分析(中断切换篇) | 系统因中断活力四射