React Hook 父子组件相互调用函数

1、子组件调用父组件函数方法

//父组件
let Father=()=>{
	let getInfo=()=>{
		
	}
	return ()=>{
		<div>
			<Children 
				getInfo={getInfo}
			/>
		</div>
	}
}
//子组件
let Children=(param)=>{
	return ()=>{
		<div>
			<span onClick={param.getInfo}>调用父组件函数</span>
		</div>
	}
}

子组件调用父组件函数,可以向父组件传参,刷新父组件信息

2、父组件调用子组件函数方法

//父组件
//需要引入useRef
import {useRef} from 'react'
let Father=()=>{
	const childRef=useRef();
	let onClick=()=>{
		childRef.current.getInfo();
	}
	return ()=>{
		<div>
			<Children 
				ref={childRef}
			/>
			<span onClick={onClick}>调用子组件函数</span>
		</div>
	}
}
//子组件 
//需要引入useImperativeHandle,forwardRef
import {useImperativeHandle,forwardRef} from 'react'
let Children=(ref)=>{
	useImperativeHandle(ref, () => ({
        getInfo:()=>{
            //需要处理的数据
        }
    }))
	return ()=>{
		<div></div>
	}
}
Children = forwardRef(Children);

useImperativeHandle 需要配合着 forwardRef 使用,要不就会出现以下警告

Warning: Function components cannot be given refs. Attempts to access this ref will fail. Did you mean to use React.forwardRef()?
  • 0
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值