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

【React】父组件如何调用子组件的方法

在React中,父组件可以通过ref来调用子组件的方法。以下是一个简单的示例,展示了如何在父组件中使用ref来调用子组件的方法。
子组件
首先,在子组件中定义一个方法,并使用forwardRef将其暴露给父组件。

注意下面的代码块中,localRef相关的代码其实不需要也可以实现这个功能;

import React, { forwardRef, useImperativeHandle, useRef } from 'react';

const ChildComponent = forwardRef((props, ref) => {
  const localRef = useRef();

  useImperativeHandle(ref, () => ({
   注意:这里放子组件将被父组件调用的方法
    scroll: (awardName, callback) => {
      console.log(
`Scrolling to ${awardName}`);
      // 执行滚动逻辑
      if (callback) callback();
    }
    
  }));

  return (
    <div ref={localRef}>
      {/* 子组件内容 */}
    </div>
  );
});

export default ChildComponent;

父组件
在父组件中,使用useRef创建一个ref,并将其传递给子组件。然后,可以通过这个ref调用子组件的方法。

import React, { useRef } from 'react';
import ChildComponent from './ChildComponent';

const ParentComponent = () => {
  const childRef = useRef();

  const handleScroll = () => {
    if (childRef.current) {
      childRef.current.scroll('Award Name', () => {
      支持回调
        console.log('Scroll completed');
      });
    }
  };

  return (
    <div>
      <ChildComponent ref={childRef} />
      <button onClick={handleScroll}>Scroll to Award</button>
    </div>
  );
};

export default ParentComponent;

解释
子组件:使用forwardRef和useImperativeHandle将scroll方法暴露给父组件。
父组件:使用useRef创建一个ref,并将其传递给子组件。通过这个ref调用子组件的scroll方法。
这样,父组件就可以调用子组件的方法了。


http://www.kler.cn/a/353817.html

相关文章:

  • Ruby语言的软件开发工具
  • 【MySQL 保姆级教学】用户管理和数据库权限(16)
  • 二十三种设计模式-原型模式
  • WebRTC 在视频联网平台中的应用:开启实时通信新篇章
  • Pytorch学习12_最大池化的使用
  • 快速学习 pytest 基础知识
  • netron安装(windows linux)
  • 通过阿里云Milvus和通义千问快速构建基于专属知识库的问答系统
  • ProteinMPNN中蛋白质特征提取
  • python的多线程和多进程
  • 【vue+printJs】前端打印, 自定义字体大小, 自定义样式, 封装共享样式
  • 【Flutter】Dart:函数
  • esp32 开发需要那些开发语言
  • paypal php 实现详细攻略
  • 4 登录接口实现(Vue3+Spring boot+mysql)
  • LeetCode322:零钱兑换
  • 图论刷题
  • 好用的python相关的AI工具Bito介绍
  • Linux多任务编程(网络编程-数据库篇)
  • 【wpf】05 几种容器动态创建控件的对比
  • 【c++篇】:初识c++--编程新手的快速入门之道(二)
  • MyBatisPlus笔记之逻辑删除、枚举处理器、JSON处理器
  • WindowsAPI|每天了解几个winAPI接口之网络配置相关文档Iphlpapi.h详细分析五
  • 微服务经典应用架构图
  • QUIC 协议的优势
  • Node.js基础与应用