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 string字符串优化问题
Jul 31 Javascript
JavaScript设置body高度为浏览器高度的方法
Feb 09 Javascript
基于jquery实现的自动补全功能
Mar 12 Javascript
简介JavaScript中getUTCMonth()方法的使用
Jun 10 Javascript
javascript遇到html5的一些表单属性
Jul 05 Javascript
利用HTML5+Socket.io实现摇一摇控制PC端歌曲切换
Jan 13 Javascript
AngularJS 打开新的标签页实现代码
Sep 07 Javascript
vue.js 使用axios实现下载功能的示例
Mar 05 Javascript
vee-validate vue 2.0自定义表单验证的实例
Aug 28 Javascript
Javascript实现秒表倒计时功能
Nov 17 Javascript
微信小程序canvas.drawImage完全显示图片问题的解决
Nov 30 Javascript
vue axios封装及API统一管理的方法
Apr 18 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内核探索:变量存储与类型使用说明
2014/01/30 PHP
PHP中nowdoc和heredoc使用需要注意的一点
2014/03/21 PHP
PHP性能优化大全(php.ini)
2016/05/20 PHP
thinkphp5实现微信扫码支付
2019/12/23 PHP
javascript基础的动画教程,直观易懂
2007/01/10 Javascript
js数字输入框(包括最大值最小值限制和四舍五入)
2009/11/24 Javascript
ExtJS 工具栏 分页事件参数
2010/03/05 Javascript
两个JavaScript jsFiddle JSBin在线调试器
2010/03/14 Javascript
javascript中setTimeout的问题解决方法
2014/05/08 Javascript
cocos2dx骨骼动画Armature源码剖析(三)
2015/09/08 Javascript
CKEditor无法验证的解决方案(js验证+jQuery Validate验证)
2016/05/09 Javascript
Bootstrap 轮播(Carousel)插件
2016/12/26 Javascript
微信小程序 自定义Toast实例代码
2017/06/12 Javascript
vue不通过路由直接获取url中参数的方法示例
2017/08/24 Javascript
jQuery实现的简单歌词滚动功能示例
2019/01/07 jQuery
7个好用的JavaScript技巧分享(译)
2019/05/07 Javascript
vue中keep-alive组件的入门使用教程
2019/06/06 Javascript
js实现飞机大战小游戏
2020/08/26 Javascript
js实现验证码干扰(静态)
2021/02/22 Javascript
使用python检测主机存活端口及检查存活主机
2015/10/12 Python
Python实现模拟分割大文件及多线程处理的方法
2017/10/10 Python
Python Unittest自动化单元测试框架详解
2018/04/04 Python
python读取txt文件并取其某一列数据的示例
2019/02/19 Python
Python调用钉钉自定义机器人的实现
2020/01/03 Python
sklearn+python:线性回归案例
2020/02/24 Python
Python学习之路之pycharm的第一个项目搭建过程
2020/06/18 Python
CSS书写规范、顺序和命名规则
2014/03/06 HTML / CSS
HTML5 Canvas 旋转风车绘制
2017/08/18 HTML / CSS
HTML5实现移动端复制功能
2018/04/19 HTML / CSS
菲律宾酒店预订网站:Hotels.com菲律宾
2017/07/12 全球购物
美国娱乐和流行文化商品店:FYE
2017/09/14 全球购物
澳大利亚优质的家居用品和生活方式公司:Bed Bath N’ Table
2019/04/16 全球购物
新年主持词
2014/03/27 职场文书
公司开业庆典策划方案
2014/06/04 职场文书
在宿舍喝酒的检讨书
2014/09/28 职场文书
python基础之文件操作
2021/10/24 Python