iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >React组件间通信的方法有哪些
  • 337
分享到

React组件间通信的方法有哪些

2023-06-25 11:06:39 337人浏览 泡泡鱼
摘要

这篇文章给大家分享的是有关React组件间通信的方法有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、父子组件通信原理:父组件通过props(与vue中的props区分开)向子组件通信,子组件通过回调事件与

这篇文章给大家分享的是有关React组件间通信的方法有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

    一、父子组件通信

    原理:父组件通过props(与vue中的props区分开)向子组件通信,子组件通过回调事件与父组件通信。

    首先,先创建一个父组件Parent.js跟子组件Children.js,二者的关系为直接父子关系。

    Parent.js父组件如下,给父组件一个默认状态state,引入子组件,通过在子组件加上toChildren={this.state.msg},该处即为向子组件传props。

    import React from 'react';import { Button } from 'element-react';import Children from './Children'; class Parent extends React.Component {  constructor(props) {super(props);this.state = {msg:'父组件传递给子组件'};    this.changeMsg = this.changeMsg.bind(this)  }  changeMsg(){    this.setState({      msg:'父组件传递给子组件(改变之后的内容)'    })  }  render(){    return (      <div style={{backgroundColor:'#f7ba2a',padding:'20px',width:'500px',margin:'auto',textAlign:'center'}}>        <p>父子组件通信实例</p>        <Button onClick={this.changeMsg}>父传子</Button>        <Children toChildren={this.state.msg}></Children>      </div>    )  }} export default Parent

    Children.js子组件如下,初始状态通过props拿到父组件传过来的值。

    import React from 'react'; class Children extends React.Component {  constructor(props) {super(props);this.state = {msg:this.props.toChildren   //通过props拿到父组件传过来的值};  }  render(){    return (      <div style={{backgroundColor:'#13ce66',padding:'10px',width:'200px',margin:'auto',marginTop:'20px'}}>        <p>从父组件传过来:</p>        <span style={{color:'blue'}}>{this.state.msg}</span>      </div>    )  }} export default Children

    React组件间通信的方法有哪些

    注意:子组件取值时应与父组件放在子组件的字段props一致,即本例中的 toChildren,如下

    React组件间通信的方法有哪些

    React组件间通信的方法有哪些

     那么子组件想向父组件传值(向上传值),可以通过调用父组件传过来的回调函数

    在Parent.js中向Children.js中加入回调函数callback,绑定changeMsg方法

    import React from 'react';import Children from './Children'; class Parent extends React.Component {  constructor(props) {super(props);this.state = {    msg:'父组件传递给子组件',        fromChildrn:''};    this.changeMsg = this.changeMsg.bind(this)  }  changeMsg(val){    this.setState({      fromChildrn: val    })  }  render(){    return (      <div style={{backgroundColor:'#f7ba2a',padding:'20px',width:'500px',margin:'auto',textAlign:'center'}}>        <p>父子组件通信实例</p>        <span style={{color:'red'}}>{this.state.fromChildrn}</span>        <Children toChildren={this.state.msg} callback={this.changeMsg}></Children>      </div>    )  }} export default Parent

    在子组件中,用this.props.callback()执行父组件的回调函数,从而执行绑定方法changeMsg,显示子组件传过来的值

    import React from 'react';import { Button } from 'element-react'; class Children extends React.Component {  constructor(props) {super(props);this.state = {msg:this.props.toChildren};    this.toParent = this.toParent.bind(this)  }  toParent(){    this.props.callback('子组件传过来的值')   //子组件通过此触发父组件的回调方法  }  render(){    return (      <div style={{backgroundColor:'#13ce66',padding:'10px',width:'200px',margin:'auto',marginTop:'20px'}}>        <p>从父组件传过来:</p>        <span style={{color:'blue'}}>{this.state.msg}</span>        <Button onClick={this.toParent}>子传父</Button>      </div>    )  }} export default Children

    注意:props中的回调函数名称需一致,即本例中的callback,如下

    React组件间通信的方法有哪些

    React组件间通信的方法有哪些

    小结: 以上为直接父子组件通信的其中一种方式,父传子,通过props;子传父,执行回调。

    二、跨级组件通信

    假设一个父组件中存在一个子组件,这个子组件中又存在一个子组件,暂且称为“孙组件”,当父组件需要与“孙组件”通信时,常用的方式有两种,逐层传值与跨层传值。

    1、逐层传值

    这种方式就是上面的直接父子通信的基础上在加上一个中间层。如父、“孙”组件通信,可以先父子通信,然后再子“孙”通信,传递的层级变成父-->子-->“孙”,同理,通过props往下传,通过回调往上传。不展开,有兴趣的自己动手实现一下。

    2、跨级传值

    顾名思义,父跟“孙”通信,不需要经过子(中间层)组件。这里引出了Context

    React官方文档对Context做出了解释:

    在一个典型的 React 应用中,数据是通过 props 属性自上而下(由父及子)进行传递的,但这种做法对于某些类型的属性而言是极其繁琐的(例如:地区偏好,UI 主题),这些属性是应用程序中许多组件都需要的。Context 提供了一种在组件之间共享此类值的方式,而不必显式地通过组件树的逐层传递 props。

    一句话概括就是:跨级传值,状态共享

    看下简单的实例,直接讲用法。

    首先,我先创建一个context.js文件(与父子孙同个目录),默认值为一个对象。

    import React from "react";const MyContext = React.createContext({text:'luck'});export default MyContext

    然后,对父组件进行改写,引入context,使用一个 Provider 来将当前的 value 传递给以下的组件树,value为传递的值。

    import React from 'react';import Children from './Children';import MyContext from './context'; class Parent extends React.Component {  constructor(props) {super(props);  }  // 使用一个 Provider 来将当前的 value 传递给以下的组件树。  // 无论多深,任何组件都能读取这个值。  render(){    return (      <div style={{backgroundColor:'#f7ba2a',padding:'20px',width:'500px',margin:'auto',textAlign:'center'}}>        <p>context通信实例</p>        <MyContext.Provider value={{text:'Good luck'}}>          <Children></Children>        </MyContext.Provider>      </div>    )  }} export default Parent

    子组件为中间层,不做处理,用于包裹“孙”组件。

    import React from 'react';import Grandson from './Grandson'; class Children extends React.Component {  render(){    return (      <div>        <Grandson></Grandson>      </div>    )  }} export default Children

    新增一个“孙”组件,同样需引入context,在组件内部添加static contextType = MyContext,此时将能通过this.context直接获取到上层距离最近的Provider传递的值,此时this.context = {text:good luck},即父组件传递value。

    import React from 'react';import MyContext from './context'; class Grandson extends React.Component {  static contextType = MyContext  render(){    return (      <div style={{backgroundColor:'#13ce66',padding:'10px',width:'200px',margin:'auto',marginTop:'20px'}}>        <p>通过context传过来:</p>        <span style={{color:'blue'}}>{this.context.text}</span>      </div>    )  }} export default Grandson

    通过this.context.text获取到传递的值。

    React组件间通信的方法有哪些

     以上的是一个父-->孙的过程,即向下的流程,如果想孙-->父向上传值,可以通过回调的方式

    对父组件进行传值修改,在传过来的对象中添加一个属性,里面绑定父组件的方法value={{text:'good luck',toParent:this.fromGranson}}

    import React from 'react';import Children from './Children';import MyContext from './context'; class Parent extends React.Component {  constructor(props) {super(props);    this.state = {      msg:''    };    this.fromGranson = this.fromGranson.bind(this)  }  fromGranson(val){    this.setState({      msg:val    })  }  // 使用一个 Provider 来将当前的 theme 传递给以下的组件树。  // 无论多深,任何组件都能读取这个值。  render(){    return (      <div style={{backgroundColor:'#f7ba2a',padding:'20px',width:'500px',margin:'auto',textAlign:'center'}}>        <p>context通信实例</p>        <span style={{color:'red'}}>{this.state.msg}</span>        <MyContext.Provider value={{text:'good luck',toParent:this.fromGranson}}>          <Children></Children>        </MyContext.Provider>      </div>    )  }} export default Parent

    然后在孙组件中添加一个按钮,绑定方法,执行函数回调

    toParent(){    this.context.toParent('孙组件向父组件传数据') }
    import React from 'react';import MyContext from './context';import { Button } from 'element-react' class Grandson extends React.Component {  static contextType = MyContext  constructor(props) {super(props);    this.toParent = this.toParent.bind(this)}  toParent(){    this.context.toParent('孙组件向父组件传数据')  }  render(){    return (      <div style={{backgroundColor:'#13ce66',padding:'10px',width:'200px',margin:'auto',marginTop:'20px'}}>        <p>通过context传过来:</p>        <span style={{color:'blue'}}>{this.context.text}</span>        <div><Button onClick={this.toParent}>context向上</Button></div>      </div>    )  }} export default Grandson

    默认的页面为:

    React组件间通信的方法有哪些

     点击按钮之后,执行context中的回调,向上传值。

    React组件间通信的方法有哪些

     不管层级有多深,都可以使用context进行向下或向上传值。

    注意:在下层组件中取的context中的字段需与value中传递字段保持一致。text与toParent

    React组件间通信的方法有哪些

    React组件间通信的方法有哪些

    以上就是Context的大致使用,更多细节请往React官方文档:

    Context – React

    三、兄弟(无嵌套)组件通信

    当两个组件互不嵌套,处在同个层级或者不同层级上,他们之间要进行通信,有以下几种常用方法

    某个组件先将值传到同一个父组件,然后在通过父组件传给另外一个组件,用到父子组件传值

    使用缓存sessionStorage、localStorage等

    如果两个组件之间存在跳转,可以使用路由跳转传值,附上详细用法

    React学习笔记 -- 组件通信之路由传参(react-router-dom)_前端菜小白leo的博客-CSDN博客

    event(发布--订阅)

    首先,安装event

    npm install event -save

    新建一个event.js

    import { EventEmitter } from 'events';export default new EventEmitter();

    然后另两个组件处于同层级(不同个父组件或者不同层级都可以)

    import React from 'react';import Grandson from './Grandson';import GrandsonOther from './GrandsonOther'; class Children extends React.Component {  render(){    return (      <div>        <Grandson></Grandson>        <GrandsonOther></GrandsonOther>      </div>    )  }} export default Children

    组件一,导入event,在componentDidMount阶段添加监听addListener(订阅),在componentWillUnmount移除监听removeListener,事件名称与组件二中emit一致。

    import React from 'react';import event from '../event';import { Button } from 'element-react' class Grandson extends React.Component {  constructor(props) {super(props);    this.state = {      msg:''    }    this.toOther = this.toOther.bind(this)  }  toOther(){    event.emit('eventMsg','通过evnet传过来的值')  }  render(){    return (      <div style={{backgroundColor:'#13ce66',padding:'10px',width:'200px',margin:'auto',marginTop:'20px'}}>        <p>组件二</p>        <span style={{color:'blue'}}>{this.state.msg}</span>        <div><Button onClick={this.toOther}>event传值</Button></div>      </div>    )  }} export default Grandson

    组件二,导入event,按钮绑定方法,使用event.emit触发(发布)事件。

    import React from 'react';import event from '../event';import { Button } from 'element-react' class Grandson extends React.Component {  constructor(props) {super(props);    this.state = {      msg:''    }    this.toOther = this.toOther.bind(this)  }  toOther(){    event.emit('eventMsg','通过evnet传过来的值')  }  render(){    return (      <div style={{backgroundColor:'#13ce66',padding:'10px',width:'200px',margin:'auto',marginTop:'20px'}}>        <p>组件二</p>        <span style={{color:'blue'}}>{this.state.msg}</span>        <div><Button onClick={this.toOther}>event传值</Button></div>      </div>    )  }} export default Grandson

    点击按钮,组件二发布事件,组件一监听(订阅)事件,更新内容。(如果交换发布者订阅者身份,写法一致)

    React组件间通信的方法有哪些

    React组件间通信的方法有哪些

    注意:如果两个组件使用event进行通信,确保发布订阅的事件名称一致,如上例中 eventMsg

    小结: event的方式比较灵活,不管是父子、跨级、还是同级,甚至毫无关联的组件,都可以使用此方式进行通信。

    感谢各位的阅读!关于“React组件间通信的方法有哪些”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

    --结束END--

    本文标题: React组件间通信的方法有哪些

    本文链接: https://www.lsjlt.com/news/304289.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • React组件间通信的方法有哪些
      这篇文章给大家分享的是有关React组件间通信的方法有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、父子组件通信原理:父组件通过props(与vue中的props区分开)向子组件通信,子组件通过回调事件与...
      99+
      2023-06-25
    • React组件间通信方式有哪些
      这篇文章主要介绍React组件间通信方式有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!组件间通信方式总结父组件 => 子组件:PropsInstance Methods子组件 => 父组件:Call...
      99+
      2023-06-06
    • Vue组件间通信的方法有哪些
      这篇“Vue组件间通信的方法有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue组件间通信的方法有哪些”文章吧。方法一...
      99+
      2023-07-05
    • Angular组件间进行通信的方法有哪些
      这篇“Angular组件间进行通信的方法有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Angular组件间进行通信的方...
      99+
      2023-07-04
    • vue组件之间通信方式有哪些
      这篇文章将为大家详细讲解有关vue组件之间通信方式有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体如下:对于vue来说,组件之间的消息传递是非常重要的,下面是我对...
      99+
      2024-04-02
    • Vue实现组件间通信的方式有哪些
      本篇内容主要讲解“Vue实现组件间通信的方式有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue实现组件间通信的方式有哪些”吧!1、Props 父 >>> 子&...
      99+
      2023-06-25
    • React组件间怎么通信
      本文小编为大家详细介绍“React组件间怎么通信”,内容详细,步骤清晰,细节处理妥当,希望这篇“React组件间怎么通信”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、父子组件...
      99+
      2024-04-02
    • vue中组件间相互通信传值的方法有哪些
      这篇文章主要讲解了“vue中组件间相互通信传值的方法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue中组件间相互通信传值的方法有哪些”吧!vue中组件之间相互通讯传值的方式我们在使...
      99+
      2023-06-29
    • vue中实现组件间通信的方式有哪些
      这篇文章给大家介绍vue中实现组件间通信的方式有哪些,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。方法一、 props / $emit父组件A通过props的方式向子组件B传递,B t...
      99+
      2024-04-02
    • React组件间通信的三种方法(简单易用)
      目录一、父子组件通信二、跨级组件通信1、逐层传值2、跨级传值三、兄弟(无嵌套)组件通信四、路由传值五、Redux  React知识中一个主要内容便是组件之间的通信,以下列举...
      99+
      2024-04-02
    • 详解React中组件之间通信的方式
      一、是什么 我们将组件间通信可以拆分为两个词: 组件 通信 回顾Vue系列的文章,组件是vue中最强大的功能之一,同样组件化是React的核心思想 相比vue,...
      99+
      2024-04-02
    • Vue3的组件通信方式有哪些
      本篇内容主要讲解“Vue3的组件通信方式有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue3的组件通信方式有哪些”吧!Props父组件传值给子组件(简称:父传子)Props 文档父组件/...
      99+
      2023-06-29
    • 详解React hooks组件通信方法
      目录一、前言二、父子组件通信1)父组件传值给子组件2)子组件传值给父组件3)跨组件传值(父传孙子组件)一、前言 组件通信是React中的一个重要的知识点,下面列举一下 react h...
      99+
      2024-04-02
    • vue组件通信方式有哪些
      vue中实现组件通信的方式有:1.通过props传递实现组件通信;2.使用ref设置父子组件实现组件通信;3.使用parent创建兄弟组件通信侨联实现组件通信;4.使用provide与inject定义祖后代组件实现组件通信;vue中实现组件...
      99+
      2024-04-02
    • React生命周期与父子组件间通信知识点有哪些
      今天小编给大家分享一下React生命周期与父子组件间通信知识点有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。声明周期很...
      99+
      2023-07-04
    • react创建组件有哪些方法
      这篇文章主要介绍了react创建组件有哪些方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。函数式组件:(1)语法:function myConponent(pro...
      99+
      2023-06-14
    • Vue组件间通信有哪几种方式
      这篇文章将为大家详细讲解有关Vue组件间通信有哪几种方式,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Vue 组件间通信有哪几种方式?Vue 组件间通信是面试常考的知识点...
      99+
      2024-04-02
    • Vue中的组件通信方式有哪些
      Vue中的组件通信方式有哪些,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。vue组件中关系说明:如上图所示, A与B、A与C、...
      99+
      2024-04-02
    • android线程间通信的方法有哪些
      Android线程间通信的方法有以下几种:1. Handler:Handler是Android中最常用的线程间通信方式。它可以将消息...
      99+
      2023-08-26
      android
    • React中组件之间通信的方式是什么
      本篇内容介绍了“React中组件之间通信的方式是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、是什么我们将组件间通信可以拆分为两个词...
      99+
      2023-06-20
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作