摘要

react 学习包括几个部分:

  • 文本渲染
  • JSX 语法
  • 组件化思想
  • 数据流

一 组件通信如何实现

父子组件之间不存在继承关系

1.1 父=》子通信

父组件可以通过 this.refs.xx 调用子组件的方法,比如 setState 等

1.2 子=》父通信

有两种方法,两个粒度:

1)利用call/apply 把父组件替换子组件方法的this对象,实现子组件调用父组件属性和方法

2)通过props 形式,把父组件方法传递给 子组件,子组件调用props 的方法,实际是 父组件在执行

1.3 子=》子通信

通过共用父组件变量的方法实现通信。

1.4 无关联组件通信

二 例子

2.1 父子通信

子组件

class childComponent extends React.Component {
onClick () {
console.log('子组件');
} render() { return (
<div>
lalala
</div>
);
}
} export default childComponent;

父组件

import ChildComponent from '../childComponent'

class FatherComponent extends React.Component {
onClick() {
console.log('父组件');
}
componentDidMount () {
this.refs.test.onClick(); // !!! 通过 refs 调用子组件的方法,比如 setState 控制子组件的更新
} render() {
return (
<div>
<ChildComponent ref="test"/>
</div>
);
}
} export default FatherComponent;

结果

打印

子组件

2.2 子父通信

子组件

class childComponent extends React.Component {
onClick () {
console.log('子组件');
this.onClick(); // 调用父组件方法
} render() {
return (
<div>
lalala
</div>
);
}
} export default childComponent;

父组件

import ChildComponent from '../childComponent'

class FatherComponent extends React.Component {
onClick() {
console.log('父组件');
}
componentDidMount () {
this.refs.test.onClick.call(this); // 传入父组件的对象
} render() {
return (
<div>
<ChildComponent ref="test"/>
</div>
);
}
} export default FatherComponent;

结果

打印

子组件

父组件

2.3 子子通信

原理就是通过共用父组件变量实现联动。

步骤如下:

1)父组件调用子组件1 方法,把 变量 a 传给 子组件1

2)子组件1 拿到变量 a 更新,调用父组件方法1

3)父组件方法1 调用子组件2 方法,把 变量 a 传给子组件2

4)子组件2 拿到变量a 更新。

子组件

class childComponent extends React.Component {
onClick () {
console.log('子组件', this.props.name);
// 2. 组件hxy 更新父组件
this.onClick();
} onClick1() {
// 4. 组件 xiaohuamao 更新
console.log('子组件', this.props.name)
} render() {
return (
<div>
{this.props.name}
</div>
);
}
} export default childComponent;

父组件

import ChildComponent from '../childComponent'

class FatherComponent extends React.Component {
onClick() {
console.log('父组件');
console.log('调用子组件test1 onClick');
// 3. 组件 xiaohuamao 更新
this.refs.test1.onClick1.call(this);
}
componentDidMount () {
console.log('调用子组件test onClick');
// 1. 父组件 调用 组件 hxy
this.refs.test.onClick.call(this);
} render() {
// 有两个子组件 hxy 和 xiaohuamao
return (
<div>
<ChildComponent ref="test" name={'hxy'}/>
<ChildComponent ref="test1" name={'xiaohuamao'}/>
</div>
);
}
} export default FatherComponent;

结果

打印

调用子组件test onClick // 调用子组件 hxy 方法

子组件 undefined // 此处 this 替换为 父组件对象

父组件 // 回到父组件

调用子组件test1 onClick // 调用子组件xiaohuamao 方法

子组件 xiaohuamao // 可更新子组件xiaohuamao 的state实现更新组件

【JAVASCRIPT】React学习- 数据流(组件通信)的更多相关文章

  1. React学习笔记 - 组件&Props

    React Learn Note 4 React学习笔记(四) 标签(空格分隔): React JavaScript 三.组件&Props 组件可以将UI切分成一些独立的.可复用的部件,这样你 ...

  2. react学习(二)之通信篇

    react性能提升原理:虚拟DOM react把真是的DOM tree,转化成virtual DOM,每次数据更新后,重新计算virtual DOM并与上一次的作对比,然后对发生改变的部分进行批量更新 ...

  3. 浅谈vue学习之组件通信

    vue用组件化简化了我们编写代码的复杂度,组件之间经常会出现数据传递的情况,那么组件之间是怎样通信的呢? 使用props传递数据 组件实例的作用域是孤立的.这意味着不能 (也不应该) 在子组件的模板内 ...

  4. 关于React的父子组件通信等等

    //==================================================此处为父子组件通信 1.子组件调用父组件: 父组件将子组件需要调用方法存入props属性内,子组 ...

  5. 【Flutter学习】组件通信(父子、兄弟)

    一,概述 flutter一个重要的特性就是组件化.组件分为两种状态,一种是StatefulWidget有状态组件,一种是StatelessWidget无状态组件. 无状态组件不能更新状态,有状态组件具 ...

  6. React学习——ListView组件

    (草稿) 先把代码放上来,再补充说明 <!DOCTYPE html> <html> <head> <title>React ListView</t ...

  7. React 学习二 组件

    React的一个最大的特点就是组件化的开发模式.今天就来试一下: <!DOCTYPE html> <html> <head> <meta charset=&q ...

  8. react.js父子组件通信

    这里通过todolist的功能来说明 父组件: import React,{ Component,Fragment } from 'react'; import TodoItem from './To ...

  9. React学习——子组件给父组件传值

    //子组件 var Child = React.createClass({ render: function(){ return ( <div> 请输入邮箱:<input onCha ...

随机推荐

  1. java计算某个日期是什么节气(24节气)

    package com.test; import java.util.Calendar; import java.util.Date; /** * Created by json */ public ...

  2. MyBatis介绍

    MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索.MyBatis 使用简单的 XML或注解用于配 ...

  3. GCTF2017部分write up

    Misc stage1 拿到题看到是一张图片隐写 用神器Stegsolve看看发现左上角藏着一张二维码 截下来,不能直接扫,需要反色处理一下 扫出来是一串十六进制 看头几个十六进制数发现是pyc文件 ...

  4. java IO文件操作简单基础入门例子,IO流其实没那么难

    IO是JAVASE中非常重要的一块,是面向对象的完美体现,深入学习IO,你将可以领略到很多面向对象的思想.今天整理了一份适合初学者学习的简单例子,让大家可以更深刻的理解IO流的具体操作. 1.文件拷贝 ...

  5. udl文件测试数据库连接

    直接建一个udl后缀的文件(新建txt文件,改后缀) 然后会默认有个小电脑标志,双击打开就可以看到,可以用来配置数据库连接信息,可以测试连接,如果连接通过,可以再用记事本打开这个udl文件,里面就有生 ...

  6. wildfly与mysql数据库连接问题

    wildfly报错: Caused by: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link f ...

  7. CSS(3)实现水平垂直居中效果

    CSS实现水平垂直居中对齐 在CSS中实现水平居中,会比较简单.常见的,如果想实现inline元素或者inline-block元素水平居中,可以在其父级块级元素上设置text-align: cente ...

  8. java对mysql的增删改查

    -----连接数据库 package connectdb;import java.sql.*;class Dbcon { // 此处连接数据库,独立开一个类,以后操作数据库的每次连接就不用写这么多 p ...

  9. Android精品源码与技术博文

    Android精品源码android遵循Material Design风格天气源码基于exoplay 自定义播放器 支持直播 1 ExoUserPlayer 基本播放器...几种动画效果Animati ...

  10. [UWP]浅谈按钮设计

    一时兴起想谈谈UWP按钮的设计. 按钮是UI中最重要的元素之一,可能也是用得最多的交互元素.好的按钮设计可以有效提高用户体验,构造让人眼前一亮的UI.而且按钮通常不会影响布局,小小的按钮无论怎么改也不 ...