react 中调用子组件方法

一、使用 `ref` 和 `forwardRef`

1. 子组件暴露方法

首先使用`forwardRef`来定义组件,使得组件可以接收`ref`。然后定义了一个`childMethod`方法,并且使用`useImperativeHandle`来将这个方法暴露给父组件。

javascript 复制代码
import { forwardRef, useImperativeHandle } from "react";

const ChildComponent = forwardRef((props, ref) => {

  const childMethod = () => {

    console.log("子组件方法被调用");

  };

  useImperativeHandle(ref, () => ({

    childMethod,

  }));

  return <div>{/* 子组件内容 */}</div>;

});

2. 父组件使用方法

父组件通过`ref`就可以访问到`childMethod`。

javascript 复制代码
import { useRef } from "react";

const ParentComponent = () => {

  const childRef = useRef();

  const handleClick = () => {

    if (childRef.current) {

      childRef.current.childMethod();

    }

  };

  return (

    <div>

      <button onClick={handleClick}>调用子组件方法</button>

      <ChildComponent ref={childRef} />

    </div>

  );

};
相关推荐
中国lanwp3 分钟前
npm中@your-company:registry 和 registry 的区别
前端·npm·node.js
Bacon5 分钟前
Electron 应用商店:开箱即用工具集成方案
前端·github
行走的陀螺仪6 分钟前
uni-app + Vue3 实现折叠文本(超出省略 + 展开收起)
前端·javascript·css·uni-app·vue3
冴羽9 分钟前
JavaScript 异步循环踩坑指南
前端·javascript·node.js
jump68011 分钟前
commonjs 和 ES Module
前端
旧曲重听133 分钟前
前端需要掌握多少Node.js?
前端·node.js
Mr.Jessy33 分钟前
Web APIs 学习第四天:DOM事件进阶
开发语言·前端·javascript·学习·ecmascript
云枫晖36 分钟前
前端工程化实战:手把手教你构建项目脚手架
前端·前端工程化
醉方休38 分钟前
开发一个完整的Electron应用程序
前端·javascript·electron
故作春风44 分钟前
手把手实现一个前端 AI 编程助手:从 MCP 思想到 VS Code 插件实战
前端·人工智能