react子组件向父组件传参

在React中,子组件向父组件传参(或称为"通信")通常通过事件回调的方式实现。父组件向子组件传递一个函数作为props,子组件在需要时调用这个函数,并可以通过参数的形式向父组件传递数据。

下面是一个简单的例子来说明这个过程:

父组件(ParentComponent)

复制代码
import React, { useState } from 'react';  
import ChildComponent from './ChildComponent';  
  
function ParentComponent() {  
  const [childData, setChildData] = useState('');  
  
  // 这是一个由父组件传递给子组件的函数,用于接收子组件的数据  
  const handleChildData = (data) => {  
    setChildData(data);  
  };  
  
  return (  
    <div>  
      <h1>Parent Component</h1>  
      <p>Data from Child: {childData}</p>  
      <ChildComponent onReceiveData={handleChildData} />  
    </div>  
  );  
}  
  
export default ParentComponent;

子组件(ChildComponent)

复制代码
import React from 'react';  
  
function ChildComponent({ onReceiveData }) {  
  // 假设这里有一个按钮,点击时会触发数据传递  
  const sendDataToParent = () => {  
    const dataToSend = 'Hello from Child!';  
    onReceiveData(dataToSend); // 调用父组件传递的函数,并传递数据  
  };  
  
  return (  
    <div>  
      <h2>Child Component</h2>  
      <button onClick={sendDataToParent}>Send Data to Parent</button>  
    </div>  
  );  
}  
  
export default ChildComponent;

在这个例子中,ParentComponent 通过props向ChildComponent传递了一个名为onReceiveData的函数。这个函数在ParentComponent中被定义,用于更新ParentComponent的state(即childData)。当ChildComponent中的按钮被点击时,它会调用onReceiveData函数,并传递一个字符串'Hello from Child!'作为参数。这样,ParentComponent就能够接收到来自ChildComponent的数据,并更新其状态,从而在UI上反映出这一变化。

这种方式是React中实现组件间通信的一种常用且有效的方式,特别适用于父子组件之间的数据传递。

相关推荐
liangshanbo121535 分钟前
写好 React useEffect 的终极指南
前端·javascript·react.js
_院长大人_3 小时前
el-table-column show-overflow-tooltip 只能显示纯文本,无法渲染 <p> 标签
前端·javascript·vue.js
SevgiliD3 小时前
el-table中控制单列内容多行超出省略及tooltip
javascript·vue.js·elementui
要加油哦~4 小时前
JS | 知识点总结 - 原型链
开发语言·javascript·原型模式
阿珊和她的猫4 小时前
深入理解与手写发布订阅模式
开发语言·前端·javascript·vue.js·ecmascript·状态模式
爱看书的小沐5 小时前
【小沐杂货铺】基于Three.js渲染三维风力发电机(WebGL、vue、react、WindTurbine)
javascript·vue.js·webgl·three.js·opengl·风力发电机·windturbine
qq_398586546 小时前
Threejs入门学习笔记
javascript·笔记·学习
浪裡遊6 小时前
Nivo图表库全面指南:配置与用法详解
前端·javascript·react.js·node.js·php
課代表6 小时前
JavaScript 二维数组的三种定义与初始化方法
javascript·初始化·二维数组·多维数组·动态数组·循环遍历·数组合并
鸡吃丸子7 小时前
Next.js 入门指南
开发语言·javascript·next.js