iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >React父子组件间的通信是怎样进行的
  • 732
分享到

React父子组件间的通信是怎样进行的

React父子组件通信React组件通信 2023-03-14 11:03:37 732人浏览 独家记忆
摘要

目录父子组件通信方式父传子子传父ref标记(传递数据)非父子组件通信方式状态提升(兄弟通信)发布订阅模式context状态树传参(跨组件方案)React插槽children实现插槽多

父子组件通信方式

(1)传递数据(父传子)与传递方法(子传父)

(2)ref标记(父组件拿到子组件的引用,从而调用子组件的方法)

父传子

使用 props属性,传入props

this.props.数据

//父组件
 <Field label="用户名"></Field>
//子组件
 <label>{this.props.label}</label>

子传父

父组件向子组件传一个函数,然后通过子组件中这个函数的回调,拿到子组件穿过的值

this.props.函数名()

//子组件
<input onChange={(evt)=>{
   this.props.onChangeEvent(evt.target.value)
}}></input>
//父组件
 <Field onChangeEvent={(value)=>{
    console.log(value)
 }}></Field>

ref标记(传递数据)

在组件身上绑定ref,直接通过 this.username.current 获得整个组件,this.username.current.state获得子组件内state数据

this.ref名.current

//子组件中
 state={
     value:''
 }
 <input onChange={(evt)=>{
   this.setState({
       value:evt.target.value
   })
}}></input>
//父组件
username = React.createRef()
<Field ref={this.username}></Filed>
....
console.log(this.username.current.state.value)

???父组件中清除子组件的值:在子组件中定义修改state函数,父组件中调用此函数来实现

clear(){
    this.setState({
        value:''
    })
}
 <input value={this.state.value}></input>
....................
this.username.current.clear()//父

非父子组件通信方式

状态提升(兄弟通信)

React中的状态提升概括来说,就是将多个组件需要共享的状态提升到它们最近的父组件上,在父组件上改变这个状态然后通过props分发给子组件

发布订阅模式

兄弟组件AB,子组件A将值传给B组件,在子组件A中发布,在子组件B中订阅,,此方法适合任意关系的通信

调度中心bus:

var bus={
	list:[],//放入所有的订阅
	//订阅
    subscribe(callback){
         this.list.push(callback)
        //callback为注册订阅的回调函数
    }
	//发布
	publish(){
    }
}

1.订阅消息

//创建订阅的回调函数
subscribe(callback){
   console.log(callback);
   this.list.push(callback)
}
//订阅者
bus.subscribe((value)=>{
    console.log(111,value);
})
bus.subscribe((value)=>{
    console.log(222,value);
})

2.发布消息

//创建bus(调度中心)中的发布函数
publish(text){
        //遍历所有的list,将回调函数执行
        // console.log(this.list);
        this.list.forEach(callback=>{
            callback && callback(text)
        })
    }
//发布者
setTimeout(()=>{
    bus.publish('沉默')
},0)

bus.publish调用时,传入参数,触发bus中publish函数并接收到数据即text,调用callback回调函数,传入text,此时调用者subscribe将收到参数为value,即将组件A数据传入组件B中

context状态树传参(跨组件方案)

Context 提供了一种在组件之间共享此类值的方式,是“全局”的数据,而不必显式地通过组件树的逐层传递 props。

context上下文对象来管理公共状态,来实现数据的修改

1.创建context对象

const GlobalContext = React.createContext()

2.创建提供数据的父组件Provider

给Provider组件设置value属性,需要传递到后代组件中的数据作为value的值

当Provider发生数据value变更时,会触发到Consumer发生渲染,所有被其包裹的子组件都会发生渲染(render被调用)

//格式
state={
    info:'111'
}
render(){
    return(
        <GlobalContext.Provider value={{
        	//key:value或key:函数
        }}>
        	<div>父组件内容</div>
        </GlobalContext.Provider>
    )
}

3.创建接受数据的子孙组件Consumer

//格式
render(){
     return(
       <GlobalContext.Consumer>
        {
            (value)=>{
                return(
                    <div onClick={()=>{
                       
                      }}>
                    </div>
                )
            }
        }
       </GlobalContext.Consumer>
    )
}

4.在子孙组件A中调用Provider中的回调函数

某些时候需要内部组件去更新Context的数据,只需要向上下文添加回调函数即可

//子组件A中  调用回调函数,传递数据
value.chageInfo(synopsis)
//父组件
state={
        info:111
}
......................................
<GlobalContext.Provider value={{
     "name":"说名字",
     "info":this.state.info,
     chageInfo:(content)=>{
         this.setState({
             info:content
         })
     }
}}>

全局定义状态,并修改状态

5.子孙组件B中接收Provider的数据

 <GlobalContext.Consumer>
        {
            (value)=><div className="filmDetail">
                //接受Provider的数据
                    detail-{value.info}
                </div>
        }
 </GlobalContext.Consumer>

实现了将组件A的值传给了组件B的值

React插槽

作用:为了复用;一定程度减少父子通信

children实现插槽

在React组件中直接包裹一些html标签,html标签内容是否会出现呢?

<Child>
    <div>111</div>
    <div>22</div>
    <div>333</div>
</Child>

由上图可见,被包裹的html标签并未被渲染出来,这是因为当读取到Child组件时,会重新渲染页面覆盖被包裹的html标签;而我们可以在Child组件中留下html标签的位置,以便来显示被包裹的html,这种做法即为 插槽

语法

使用props的固定属性children在Child组件中占位

this.props.children
//该属性中包含子组件标签开始到结束之间的内容

父组件的子组件标签中写入要插入到子组件的html标签

export default class App extends Component {
  render() {
    return (
      <div>
        <Child>
            <div>111</div>
            <div>22</div>
            <div>333</div>
        </Child>
      </div>
    )
  }
}

在子组件中放入该标签

class Child extends Component{
    render(){
        return(
            <div>
                child
                 {this.props.children}
            </div>
        )
    }
}

多个元素的children

如果children中有多个元素,那么children为一个数组,数组中放着所有存放的内容

//父组件
<Child>
            <div>111</div>
            <div>22</div>
            <div>333</div>
</Child>
//子组件
<div>
    child
    <h3>以下获得所有内容</h3>
     {this.props.children}
     <h3>以下获得数组其中的元素</h3>
     {this.props.children[1]}
</div>

注意:以上方法实现了 可以通过被 插槽的内容来直接操作父组件,以此给子组件传递数据(被 插入的内容连同数据一起插入子组件中)

到此这篇关于React父子组件间的通信是怎样进行的的文章就介绍到这了,更多相关React组件通信内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: React父子组件间的通信是怎样进行的

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

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

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

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

下载Word文档
猜你喜欢
  • React父子组件间的通信是怎样进行的
    目录父子组件通信方式父传子子传父ref标记(传递数据)非父子组件通信方式状态提升(兄弟通信)发布订阅模式context状态树传参(跨组件方案)React插槽children实现插槽多...
    99+
    2023-03-14
    React父子组件通信 React组件通信
  • React父子组件间的通信是如何进行的
    本篇内容介绍了“React父子组件间的通信是如何进行的”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!父子组件通信方式(1)传递数据(父传子)...
    99+
    2023-07-05
  • vue父子组件进行通信方式是怎样的
    这篇文章主要介绍“vue父子组件进行通信方式是怎样的”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue父子组件进行通信方式是怎样的”文章能帮助大家解决问题。如图所示,父组件向子组件传递数据,可以通...
    99+
    2023-06-29
  • Angular父子组件间如何进行通信
    小编给大家分享一下Angular父子组件间如何进行通信,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!组件通信组件是一个完整独立的...
    99+
    2024-04-02
  • vue父子组件进行通信方式原来是这样的
    目录一、props二、细节三props大小写命名三、非props的attributes属性四、子组件传递给父组件五、简单例子总结在vue中如何实现父子组件通信,本篇博客将会详细介绍父...
    99+
    2024-04-02
  • Angular中父子组件间如何进行通信
    今天就跟大家聊聊有关Angular中父子组件间如何进行通信,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。通过Input和Ouput传值父组件:htm...
    99+
    2024-04-02
  • vue中怎样实现父子组件间通信
    今天就跟大家聊聊有关vue中怎样实现父子组件间通信,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。建两个组件father.vue和child.vue作...
    99+
    2024-04-02
  • vue父子组件间怎么进行通讯
    本文小编为大家详细介绍“vue父子组件间怎么进行通讯”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue父子组件间怎么进行通讯”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。如何解决组件之间通讯呢?解决方案:可以...
    99+
    2023-06-30
  • React中父子组件通信详解
    目录父组件向子组件通信存在期父组件向子组件通信 在父组件中,为子组件添加属性数据,即可实现父组件向子组件通信。传递的数据可以分成两类 子组件是作为属性来接收这些数据的 第一类就是数据...
    99+
    2024-04-02
  • Vue中父子组件间怎么通信的
    本篇内容主要讲解“Vue中父子组件间怎么通信的”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue中父子组件间怎么通信的”吧!Vue父子组件什么是父子组件?在一个组件中引入另一个组件,被引入的就...
    99+
    2023-06-21
  • React如何实现父子组件通信
    这篇文章主要介绍React如何实现父子组件通信,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!父子组件通信原理:父组件通过props(与vue中的props区分开)向子组件通信,子组件...
    99+
    2024-04-02
  • 浅析Vue中父子组件间怎么通信(父传子|子传父)
    1、父组件传递给子组件⭐⭐父组件传递给子组件:通过props属性;【相关推荐:vuejs视频教程、web前端开发】子组件传递给父组件:通过$emit触发事件;  这里我们知道,父组件有一些数据需要子组件来进行展示,那我们可以通过props来...
    99+
    2022-11-22
    组件通信 组件 Vue
  • React父子组件传值(组件通信)的实现方法
    目录1、父组件传值子组件2、子组件传值父组件3、兄弟组件传值1、父组件传值子组件 在引用子组件的时候传递,相当于一个属性,例如:在子组件内通过porps.param获取到这个para...
    99+
    2024-04-02
  • vue父子组件间通信怎么实现
    本篇内容介绍了“vue父子组件间通信怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.父组件传递数据给子组件父组件数据如何传递给子组...
    99+
    2023-07-04
  • Vue中父子组件间通信的方法是什么
    这篇文章主要讲解了“Vue中父子组件间通信的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue中父子组件间通信的方法是什么”吧!1、父组件传递给子组件父组件传递给子组件:通过pr...
    99+
    2023-07-04
  • vue2.0父子组件间通信的示例分析
    这篇文章主要介绍了vue2.0父子组件间通信的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1.父组件传递数据给子组件父组件数据如何...
    99+
    2024-04-02
  • vue中怎么实现父子组件间通信
    这篇文章将为大家详细讲解有关vue中怎么实现父子组件间通信,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。组件间通信($parent $refs)父组件要想获...
    99+
    2024-04-02
  • Vue3父子组件间通信、组件间双向绑定的方法
    父子组件可通过事件 进行通信前面的笔记 —— 《Vue3 | 组件的定义及复用性、局部组件、全局组件、组件间传值及其校验、单项数据流、Non-props属性》,单向数据流的概念,即子组件无法修改来自父组件的数据字段,假如确要修改,可以使用下...
    99+
    2023-05-15
    Vue3
  • vue组件间的通信,子组件向父组件传值的方式是什么
    今天小编给大家分享一下vue组件间的通信,子组件向父组件传值的方式是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、子...
    99+
    2023-07-05
  • react父子组件指的是什么
    这篇文章主要介绍了react父子组件指的是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇react父子组件指的是什么文章都会有所收获,下面我们一起来看看吧。 ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作