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

React组件间通信的几种方式

一、Props向下传递(Top-Down Propagation)

父组件通过props将其状态或数据传递给子组件。

父组件:

class ParentComponent extends React.Component {state = { message: 'Hello World' };render() {return <ChildComponent message={this.state.message} />;}
}

子组件;

class ChildComponent extends React.Component {render() {return <div>{this.props.message}</div>;}
}

二、Callback函数

父组件向子组件传递一个回调函数,子组件在需要时调用这个函数与父组件通信。

父组件:

class ParentComponent extends React.Component {handleData = (data) => {console.log('Received from child:', data);};render() {return <ChildComponent sendData={this.handleData} />;}
}

子组件:

class ChildComponent extends React.Component {someEvent = () => {this.props.sendData('Data from child');};render() {return <button onClick={this.someEvent}>Send Data to Parent</button>;}
}

三、Lifting State Up(状态提升)

当多个组件需要共享状态时,可以将状态提升到它们共同的父组件中。

父组件:

class ParentComponent extends React.Component {state = { sharedData: 'Shared Data' };render() {return (<><ChildA sharedData={this.state.sharedData} /><ChildB sharedData={this.state.sharedData} /></>);}
}

子组件A和B:

class ChildComponent extends React.Component {render() {return <div>{this.props.sharedData}</div>;}
}

四、 Context(上下文)

React的Context API允许你共享值给组件树中的所有组件,而不必显式地通过每个层级传递props

创建Context:

const MyContext = React.createContext(defaultValue);

提供Context值:

<MyContext.Provider value={/* 一些值 */}>{/* 组件树 */}
</MyContext.Provider>

在子组件中使用Context:

class ChildComponent extends React.Component {render() {return (<MyContext.Consumer>{value => <div>{value}</div>}</MyContext.Consumer>);}
}

或者使用useContext钩子:

import { useContext } from 'react';const ChildComponent = () => {const value = useContext(MyContext);return <div>{value}</div>;
};

五、Custom Hooks(自定义钩子)

自定义钩子允许你提取组件逻辑,使其可以在多个组件间重用。

自定义钩子:

function useCustomHook() {const [state, setState] = useState(initialState);// 钩子的逻辑...return state;
}

在组件中使用自定义钩子:

const Component = () => {const state = useCustomHook();return <div>{state}</div>;
};

六、 Higher-Order Components(高阶组件)

高阶组件是React中的一个高级技术,它通过包装一个组件来扩展其功能。

高阶组件:

function enhanceComponent(WrappedComponent) {return class extends React.Component {// 扩展逻辑...render() {return <WrappedComponent {...this.props} />;}};
}
//使用高阶组件:const EnhancedComponent = enhanceComponent(OriginalComponent);

http://www.lryc.cn/news/398201.html

相关文章:

  • 2024最新国际版抖音TikTok安装教程,免root免拔卡安卓+iOS,附全套安装工具!
  • kafka与zookeeper的SSL认证教程
  • 为何数字化转型项目会夭折?深入分析失败的关键因素
  • 数据结构(其二)--线性表
  • 软链接node_modules
  • Apache中使用SSI设置
  • Java Stream API详解:高效处理集合数据的利器
  • Python使用策略模式和openpyxl库创建Excel文件并追加内容
  • libcoap3对接华为云平台
  • 【鸿蒙学习笔记】关系型数据库概述
  • Find My网球拍|苹果Find My技术与网球拍结合,智能防丢,全球定位
  • windows环境下部署多个端口Tomcat服务和开机自启动设置保姆级教程
  • 科普文:一文搞懂jvm实战(四)深入理解逃逸分析Escape Analysis
  • 中文大模型发展到哪一个阶段了?
  • 【PostgreSQL】Spring boot + Mybatis-plus + PostgreSQL 处理json类型情况
  • 华为910b推理Qwen1.5-72b
  • legoloam算法环境配置和调试笔记
  • 如何用CSS3画一个三角形?
  • 不同型号的GD32 MCU如何区分?
  • 关于windows下编译xLua插件的流程记录
  • Hadoop简明教程
  • 基于STM32设计的药品柜温湿度监测系统(华为云IOT)(184)
  • SpringBoot源码阅读(10)——后处理器
  • 【源码开源】C#桌面应用开发:串口调试助手
  • malloc与free函数的用法(精简全面 · 一看即懂)
  • 强制升级最新系统,微软全面淘汰Win10和部分11用户
  • java-命令行连接 mysql
  • RK3588部署YOLOV8-seg的问题
  • Python Linux下编译
  • SpringMVC(3)——SpringMVC注解实战