我的编程空间,编程开发者的网络收藏夹
学习永远不晚

React的组件通讯是什么

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

React的组件通讯是什么

本篇文章为大家展示了React的组件通讯是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

    组件通讯介绍

    内容

    • 组件是独立且封闭的单元,默认情况下,只能使用组件自己的数据。

    • 在组件化过程中,我们将一个完整的功能拆分成多个组件,以更好的完成整个应用的功能。

    • 而在这个过程中,多个组件之间不可避免的要共享某些数据

    • 为了实现这些功能,就需要打破组件的独立封闭性,让其与外界沟通。这个过程就是组件通讯。

    三种方式

    • 父子组件之间

    • 兄弟组件之间

    • 跨组件层级

    小结

    组件中的状态是私有的,也就是说,组件的状态只能在组件内部使用,无法直接在组件外使用

    组件通讯-父传子

    内容:

    • 父组件提供要传递的state数据

    • 给子组件标签添加属性,值为 state 中的数据

    • 子组件中通过 props 接收父组件中传递的数据

    核心代码

    父组件提供数据并且传递给子组件

    class Parent extends React.Component {    state = { lastName: '王' }    render() {        return (            <div>                传递数据给子组件:<Child name={this.state.lastName} />            </div>        )    }}

    子组件接收数据

    function Child(props) {return <div>子组件接收到数据:{props.name}</div>}

    组件通讯-子传父

    思路

    利用回调函数,父组件提供回调,子组件调用,将要传递的数据作为回调函数的参数。

    步骤

    父组件

    定义一个回调函数f(将会用于接收数据)

    将该函数f作为属性的值,传递给子组件

    子组件

    通过 props 获取f

    调用f,并传入将子组件的数据

    核心代码

    父组件提供函数并且传递给子组件

    class Parent extends React.Component {    state: {      num: 100    }    f = (num) => {        console.log('接收到子组件数据', num)    }    render() {        return (            <div>            子组件:<Child f={this.f} />            </div>        )    }}

    子组件接收函数并且调用

    class Child extends React.Component {    handleClick = () => {      // 调用父组件传入的props,并传入参数    this.props.f(100)    }    return (    <button onClick={this.handleClick}>点我,给父组件传递数据</button>    )}

    小结

    子传父:在子组件中调用从父组件中定义的方法,并根据需要传入参数

    组件通讯-兄弟组件

    在React中没有确定的兄弟组件,就没有这个说法哈,有的只有状态提升.

    思路

    • 将共享状态提升到最近的公共父组件中,由公共父组件管理这个状态

    • 思想:状态提升

    • 公共父组件职责:

      • 提供共享状态

      • 提供操作共享状态的方法

    • 要通讯的子组件只需通过 props 接收状态或操作状态的方法

    React的组件通讯是什么

    核心代码

    parent.js

    import React, { Component } from 'react'import ReactDOM from 'react-dom'import Jack from './Jack'import Rose from './Rose'class App extends Component {  // 1. 状态提升到父组件  state = {    msg: '',  }  render() {    return (      <div>        <h2>我是App组件</h2>        <Jack say={this.changeMsg}></Jack>        {}        <Rose msg={this.state.msg}></Rose>      </div>    )  }  changeMsg = (msg) => {    this.setState({      msg,    })  }}// 渲染组件ReactDOM.render(<App />, document.getElementById('root'))

    Son1.js

    import React, { Component } from 'react'export default class Jack extends Component {  render() {    return (      <div>        <h4>我是Jack组件</h4>        <button onClick={this.say}>说</button>      </div>    )  }  say = () => {    this.props.say('you jump i look')  }}

    Son2.js

    import React, { Component } from 'react'export default class Rose extends Component {  render() {    return (      <div>        <h4>我是Rose组件-{this.props.msg}</h4>      </div>    )  }}

    组件通讯 -跨级组件通讯

    想在vue中使用跨级组件通讯,需要使用Context

    使用Context的步骤

    共三步:

    导入并调用createContext方法,从结果中解构出 Provider, Consumer 组件

    import { createContext } from 'react'const { Provider, Consumer } = createContext()

    使用 Provider 组件包裹根组件,并通过 value 属性提供要共享的数据

    return (  <Provider value={ 这里放要传递的数据 }>  <根组件的内容/>  </Provider>)

    在任意后代组件中,使用第2步中导出的Consumer组件包裹整个组件

    return (<Consumer>  {      (data) => {      // 这里的形参data 就会自动接收Provider中传入的数据        // console.log(data)      return <组件的内容>    }    }  </Consumer>)

    落地代码

    建立context.js文件

    import { createContext } from 'react'const { Provider, Consumer } = createContext()export { Consumer, Provider }

    改造根组件

    import { Provider } from './context'render () {    return (      <Provider value={{ num: this.state.num }}>        <div>          根组件, num: {this.state.num}          <Parent />          <Uncle />        </div>      </Provider>    )  }

    改造后代组件 Uncle.js

    import React from 'react'import { Consumer } from './context'export default class Uncle extends React.Component {  render () {    return (      <Consumer>        {(data) => {          return <div>我是Uncle组件, {data.num}</div>        }}      </Consumer>    )  }}

    上述内容就是React的组件通讯是什么,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网行业资讯频道。

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    React的组件通讯是什么

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

    下载Word文档

    猜你喜欢

    React的组件通讯是什么

    本篇文章为大家展示了React的组件通讯是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。组件通讯介绍内容组件是独立且封闭的单元,默认情况下,只能使用组件自己的数据。在组件化过程中,我们将一个完整
    2023-06-25

    React中组件之间通信的方式是什么

    本篇内容介绍了“React中组件之间通信的方式是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、是什么我们将组件间通信可以拆分为两个词
    2023-06-20

    React组件的生命周期是什么

    这篇文章主要讲解了“React组件的生命周期是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“React组件的生命周期是什么”吧!React生命周期1、初始化阶段componentDidM
    2023-07-05

    React函数式组件与类组件的不同点是什么

    本文小编为大家详细介绍“React函数式组件与类组件的不同点是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“React函数式组件与类组件的不同点是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。区别区别函
    2023-06-29

    react hooks组件间的传值方式是什么

    这篇文章给大家介绍react hooks组件间的传值方式是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。父传子通过props传值,使用useState来控制state的状态值父组件 Father.tsx里:子组件
    2023-06-25

    react推荐函数组件的原因是什么

    这篇文章主要讲解了“react推荐函数组件的原因是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“react推荐函数组件的原因是什么”吧!原因:1、函数组件语法更短、更简单,这使得它更容易
    2023-07-04

    Vue组件的通信方式是什么

    本篇内容主要讲解“Vue组件的通信方式是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue组件的通信方式是什么”吧!组件间通信的概念开始之前,我们把组件间通信这个词进行拆分组件通信都知道组
    2023-07-06

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录