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;
相关推荐
前端程序猿i12 分钟前
用本地代理 + ZIP 打包 + Excel 命名,优雅批量下载跨域 PDF
前端·javascript·vue.js·html
Danny_FD21 分钟前
Vue2 中使用vue-markdown实现编辑器
前端·javascript·vue.js
用户游民21 分钟前
Flutter 项目热更新加载 libapp.so 文件
前端
coding随想21 分钟前
Vue和React对DOM事件流的处理方法解析
前端
用户479492835691523 分钟前
字节面试官:forEach 为什么不能被中断?
前端·javascript
ccnocare23 分钟前
window.electronAPI.send、on 和 once
前端·electron
tager28 分钟前
🍪 让你从此告别“Cookie去哪儿了?”
前端·javascript·后端
阿吉被迫了解低代码34 分钟前
前端:“学算法?狗都不... !”
前端
前端赵哈哈39 分钟前
Vue 3 + TypeScript 项目模板
前端·vue.js·vite
南囝coding42 分钟前
命令行神器 The Fuck,敲错命令的后悔药
前端·后端