用react怎么使用子组件的引用 (function)

在React函数组件中,可以使用 useRef hook 来创建一个引用对象,并将其传递给子组件。下面是一个简单的示例:

import { useRef } from 'react';

function ParentComponent() {
  const childRef = useRef(null);

  const handleClick = () => {
    childRef.current.doSomething(); // 调用子组件的方法
  };

  return (
    <>
      <ChildComponent ref={childRef} />
      <button onClick={handleClick}>调用子组件方法</button>
    </>
  );
}

const ChildComponent = React.forwardRef((props, ref) => {
  const doSomething = () => {
    console.log('子组件被调用了');
  };

  // 将ref与子组件关联起来
  React.useImperativeHandle(ref, () => ({
    doSomething,
  }));

  return <div>子组件</div>;
});

在该示例中,父组件 ParentComponent 创建了一个 childRef 引用对象,并将其作为 ref 属性传递给子组件 ChildComponentChildComponent 使用 forwardRef 方法包裹函数组件,并在其中定义了一个 doSomething 方法。使用 useImperativeHandle hook 可以将 ref 对象与子组件实例关联起来,并暴露出一个 doSomething 方法。

最后,在父组件中,我们可以通过 childRef.current.doSomething() 来调用子组件的 doSomething 方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值