react v-18父组件调用子组件的方法和数据

版本

javascript 复制代码
"react": "^18.1.0",
"react-dom": "^18.1.0",

父组件

javascript 复制代码
import React, { useState, useRef, memo, useEffect } from "react";
import { useTranslation } from "react-i18next";
import { Card } from "antd";

import Childdren from './child/child';
function Dashboard() {
  let childRef:any = useRef(null);
  const handleClick = () => {
     console.log('子组件:', childRef.current)  //打印:{num: 999, add: ƒ}
    childRef.current.add() //调用
  }
  return (
        <Card style={{ minHeight: "calc(100vh - 64px)" }}>
            <Childdren ref={childRef} title={'我是父组件的数据'} num={123} fun={() => alert('传递了一个函数')} />
            
            <button onClick={handleClick}>父组件调子组件方法</button>
        </Card>
  );
}

export default Dashboard;

子组件 (通过useImperativeHandle() 抛出)

javascript 复制代码
// props (类组件则使用this.props)
import React, { useImperativeHandle } from "react";
const Childdren = React.forwardRef((props:any, ref) => {
  useImperativeHandle(
    ref,
    () => ({ add,num }) //父组件通过ref获取值,要在这里抛出
  );
  const num = 999;
  const add = () => {
    console.log('我是子组件方法')
  };
  return (
    <div>
      <h1>父传子:{props.title}</h1>
      <button >这是子组件</button>
      
    </div>
  );
});
export default Childdren;
相关推荐
Pedantic10 分钟前
swift 日期与时间的三个结构体
前端
南方kenny10 分钟前
Mock.js:前端开发的假数据神器
前端·javascript
芹丸子11 分钟前
vue cli 创建项目一直失败
前端
鹏程十八少15 分钟前
6.android Vivo手机 指纹解锁动画 (附源码)
前端
AliciaIr15 分钟前
深入理解React Hook:useRef的底层机制与高级应用
前端·react.js
子林super15 分钟前
Linux下各种连接数配置及高并发Nginx优化
前端
Dream耀19 分钟前
CSS过渡 vs 动画:都有哪些技巧
前端·css
程思扬20 分钟前
无界设计新生态:Penpot开源平台与cpolar的云端协同创新实践
大数据·linux·服务器·前端·经验分享·ubuntu·开源
1024小神21 分钟前
Cocos游戏开发中,如何动态加载资源和远程资源 resources
前端·javascript
圆心角21 分钟前
浏览器垃圾回收机制-面试足够了
前端·浏览器·v8