react开发教程之React 组件之间的通信方式


Posted in Javascript onAugust 12, 2017

这两天学习了React感觉组件通信这个地方知识点挺多的,而且很重要,所以,今天添加一点小笔记。

父子组件通讯

通讯手段

这是最常见的通信方式,父组件只需要将子组件需要的props传给子组件,子组件直接通过this.props来使用。

通讯内容

更多要提的是如何合理的设置子组件的props,要想将子组件设计成一个复用性强的通用组件,需要将能够复用的部分抽象出来,抽象出来的props有两种形成,一种是简单的变量,另一种是抽象出来处理某种逻辑函数。

以Header 组件为例

react开发教程之React 组件之间的通信方式

//HeaderBar.jsx 子组件

import React, { Component } from 'react';

class Header extends Component {
  constructor() {
    super();
    this.handleClick = (e) => {
      console.log(this)
    }
  }

  renderLeftComponent() {

    let leftDOM = {};
    if (this.props.renderLeftComponent) {
      return this.props.renderLeftComponent();
    }

    if (this.props.showBack) {
      let backFunc = this.props.onBack || this.goBack;
      leftDOM = (<a onClick={backFunc.bind(this)}><i className="icon left-icon icon-left-arrow"></i></a>);
    }
    return leftDOM;
  }
  

  renderRightComponent() {
    if (this.props.renderRightComponent) {
      return this.props.renderRightComponent();
    }
  }

  goBack() {
    alert("返回上一页")
  }

  render() {
    return (
      <header className="header-bar">
        {this.renderLeftComponent()}
        <span>{this.props.title || '滴滴'}</span>
        {this.renderRightComponent()}
      </header>
    );
  }
}

export default Header;

//父亲组件部分代码App.jsx
import HeaderBar from "./components/Header";

let leftIcon = function () {
 return (
  <a><i className="icon left-icon icon-left-haha"></i>左边按钮</a>
 )
}
class App extends Component {

 render() {
  return (
   <div className="App">
    <HeaderBar title="滴滴打车" renderLeftComponent={leftIcon} />
   </div>
  );
 }
}

子父组件通讯

父-子组件通信的手段是通过子组件的props是子组件用父组件的东西,子-父组件通信,是父组件用子组件的东西,暂时了解的两种方法

利用回调函数

父组件通过props传递一个方法给子组件,子组件通过props方法将子组件数据传递给父组件

利用ref

父组件通过refs调用子组件的属性

跨级组件通信

在React中当一个属性反复使用并且存在与好几个子组件中的时候,这个时候我们如果通过props一级一级传递的话可以实现多层级访问,但是这样出现一个问题就是会使代码非常混乱,在React中国年,我们还可以使用 context 来实现跨级父子组件间的通信;

在react中context称为虫洞

// Component 父级
class parentComponent extends React.Component {
  
  // add the following property
  static childContextTypes = {
    color: React.PropTypes.string
  }
  
  // 添加下面方法
  getChildContext() {
    return {
      color: "#f00"
    }
  }
  
  render() {
    <div>
      <Child1 />
    </div>
  }
}


// Component Child1
class Child1 extends React.Component {
  // 添加下面属性
  static contextTypes = {
    color: React.PropTypes.string
  }
  
  render() {
    <div>{this.context.color}</div>
  }
}

同级组件通信

同级组件之间的通信还是需要通过父组件作为中介,利用多次父-子组件通信,项目中将需要传递的数据放在了父组件的state中,变动时可以自动的同步传递。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
国外的为初学者写的JavaScript教程
Jun 09 Javascript
jQuery实战之品牌展示列表效果
Apr 10 Javascript
JavaScript开发人员的10个关键习惯小结
Dec 05 Javascript
jQuery实现仿美橙互联两级导航菜单效果完整实例
Sep 17 Javascript
JavaScript中ES6字符串扩展方法
Aug 26 Javascript
Angular学习笔记之angular的$filter服务浅析
Nov 12 Javascript
assert()函数用法总结(推荐)
Jan 25 Javascript
vue 引入公共css文件的简单方法(推荐)
Jan 20 Javascript
微信小程序实现星级评价效果
Dec 28 Javascript
vue-i18n结合Element-ui的配置方法
May 20 Javascript
jQuery实现本地存储
Dec 22 jQuery
JS removeAttribute()方法实现删除元素的某个属性
Jan 11 Javascript
vuejs+element-ui+laravel5.4上传文件的示例代码
Aug 12 #Javascript
浅谈关于angularJs中使用$.ajax的注意点
Aug 12 #Javascript
详解Vue-Cli 异步加载数据的一些注意点
Aug 12 #Javascript
js模块加载方式浅析
Aug 12 #Javascript
浅谈angular2 组件的生命周期钩子
Aug 12 #Javascript
Node.js pipe实现源码解析
Aug 12 #Javascript
vue实现移动端图片裁剪上传功能
Aug 18 #Javascript
You might like
PHP 分页类(模仿google)-面试题目解答
2009/09/13 PHP
PHP里8个鲜为人知的安全函数分析
2014/12/09 PHP
PHP常见漏洞攻击分析
2016/02/21 PHP
PHPExcel导出2003和2007的excel文档功能示例
2017/01/04 PHP
php创建多级目录与级联删除文件的方法示例
2019/09/12 PHP
自写的一个jQuery圆角插件
2010/10/26 Javascript
jQuery中事件对象e的事件冒泡用法示例介绍
2014/04/25 Javascript
JS组件Bootstrap ContextMenu右键菜单使用方法
2016/04/17 Javascript
微信小程序手势操作之单触摸点与多触摸点
2017/03/10 Javascript
Vue学习笔记进阶篇之函数化组件解析
2017/07/21 Javascript
JavaScript对JSON数据进行排序和搜索
2017/07/24 Javascript
vue项目中使用axios上传图片等文件操作
2017/11/02 Javascript
redux-saga 初识和使用
2018/03/10 Javascript
angular 实现下拉列表组件的示例代码
2019/03/09 Javascript
在CentOS上配置Nginx+Gunicorn+Python+Flask环境的教程
2016/06/07 Python
Python编程实现微信企业号文本消息推送功能示例
2017/08/21 Python
利用Python-iGraph如何绘制贴吧/微博的好友关系图详解
2017/11/02 Python
python PyTorch预训练示例
2018/02/11 Python
用 Python 连接 MySQL 的几种方式详解
2018/04/04 Python
django模板加载静态文件的方法步骤
2019/03/01 Python
python 列表输出重复值以及对应的角标方法
2019/06/11 Python
深入解析神经网络从原理到实现
2019/07/26 Python
利用python实现平稳时间序列的建模方式
2020/06/03 Python
pytorch 移动端部署之helloworld的使用
2020/10/30 Python
Crocs卡骆驰洞洞鞋日本官方网站:Crocs日本
2016/08/25 全球购物
英国123鲜花网站:123 Flowers
2019/07/07 全球购物
专科毕业生就业推荐信
2013/11/01 职场文书
节约用水演讲稿
2014/05/21 职场文书
员工年终自我评价
2014/09/14 职场文书
2014国庆节主题活动方案:快乐的国庆节
2014/09/16 职场文书
办公室卫生管理制度
2015/08/04 职场文书
导游词之西江千户苗寨
2019/12/24 职场文书
Python实战之用tkinter库做一个鼠标模拟点击器
2021/04/27 Python
原生JavaScript实现简单五子棋游戏
2021/06/28 Javascript
MySQL命令无法输入中文问题的解决方式
2021/08/30 MySQL
Python必备技巧之函数的使用详解
2022/04/04 Python