摘要

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. Vue爬坑之vuex初识

    在 Vue.js 的项目中,如果项目结构简单, 父子组件之间的数据传递可以使用  props 或者 $emit 等方式 http://www.cnblogs.com/wisewrong/p/62660 ...

  2. AmpOne

    AmpOne 基于Windows平台的Apache .PHP.Mysql 开发环境 | One intergrated tools package of Apache + PHP + MySQL fo ...

  3. 快速排序(Quicksort)的Javascript实现

    日本程序员norahiko,写了一个排序算法的动画演示,非常有趣. 这个周末,我就用它当做教材,好好学习了一下各种排序算法. 排序算法(Sorting algorithm)是计算机科学最古老.最基本的 ...

  4. Java基础——多态

    多态性是指允许不同类型的对象对同一消息做出相应.具有灵活性.抽象.行为共享.代码共享的优势,共享就意味着最大化利用和简洁,还有就是加载速度. 一.多态的作用 消除类型之间的耦合关系.即同一事件发生在不 ...

  5. JQuery 实现返回顶部

    1.添加html <div id="back-to-top"> <a href="javascript:;" title="返回顶部 ...

  6. mysql数据导入方法

      1. 通过mysql-workbench的Data Import/Restore功能    1) 有的命令不支持,比如LOAD DATA LOCAL INFILE    2) 好处是可以和DB的模 ...

  7. springmvc环境下使用ajaxfileupload.js进行文件上传

    controller: /* #region */ @RequestMapping(produces = "text/html;charset=UTF-8", value = &q ...

  8. Java基础语法实例(2)——实习第二天

    来到广州实习的第二天,广州好潮湿,这就是我的感觉,手表里面都开始产生了水雾,这就尴尬了...每天不断的雨.好吧,尽管我很喜欢这里的树,但是我以后应该也不会再来广州了,其实也说不准.想起了<谁动了 ...

  9. [USACO4.2]草地排水Drainage Ditches

    题目背景 在农夫约翰的农场上,每逢下雨,贝茜最喜欢的三叶草地就积聚了一潭水.这意味着草地被水淹没了,并且小草 要继续生长还要花相当长一段时间.因此,农夫约翰修建了一套排水系统来使贝茜的草地免除被大水淹 ...

  10. eclipse快捷键 自己使用简单总结

    ctrl+shift+O 清理代码引用的多余类 ctrl+shift+R 打开指定文件