Vue.js中父子组件数据传递:Props Down ,  Events Up

Angular中父子组件数据传递:Props Down,  Events  Up

React中父子组件数据传递:Props  Down,Props  Up

一、React中父子组件数据传递

父 => 子:父亲通过子组件的自定义属性,把自己的数据传递下去

Parent.js:

<Child      myNameInChild={this.state.myNameParent}/>

Child.js:

<h3>{this.props.myNameInChild}的照片墙</h3>

子  =>父:   父亲通过子组件的自定义属性,把自己的方法传递下去;子组件调用此方法,传递实参.

"Props Up"的原理:

Parent.js:

doModifyMyName = (newName)=>{    }

<Child  modifyName={ this.doModifyMyName }/>

Child.js:

this.props.modifyName('ABC');

Parent  p =new  Parent()

p.doModifyMyName  =   function(newName){ .....  }

Child  c =new  Child()

c.modifyMyName  = p.doModifyMyName    //父的方法传给子

c.modifyMyName('ABC');

React中没有直接的兄弟间数据传递机制,只能借助父组件: 兄弟1 => 父组件 => 兄弟2

Parent.js

constructor(){

super()

this.c2 = React.createRef()   //子组件的引用

}

---------------------------------------------------------------

<h3.MyC03   ref={this.c3}>           //子组件的引用绑定到某个孩子

---------------------------------------------------------------------

this.c3.current    是孩子对象

Vue.js中父组件获得子组件的引用:

<Child  ref="c2"/>

this.$refs.c2

------------------------------------

<Child  #c2/>

@ViewChild('c2',{static:true})

private    child2

------------------------------------

React中父组件获得子组件的引用

<Child  ref={ }/>

二、理论知识补充:  class中的静态(static)成员

类(class) 中的成员分为两大类:

①实例成员:实例属性、实例方法

②静态成员:静态属性、静态方法

三、面试题:React中组件的生命周期钩子函数 ------比较凌乱

提示: React不同版本中生命周期钩子函数各不相同!React16.3和React16.4中的都不相同!

React组件的生命周期钩子函数分为三组:

1)首次渲染相关函数

①contstructor()

②componentWillMount()  (已废弃)===getDeriveStateFormProps()  用于将this.props转为this.state

③render()

④componentDidMount()             用于初始化组件中的数据,如异步获取服务器端数据

 2)二次渲染相关函数(props属性更改、setState状态修改)

①getDerivedStateFromProps()       需要返回转换得到state对象或null

②shouldComponentUpdate()        需要返回true或false

③render()

④componentDidUpdate()

 3)组件卸载相关函数

           ①componentWillUnmount()          用于销毁组件创建的长期存在的数据,如定时器...

 强化记忆:三大框架,组件加载完成和卸载完成钩子函数

   Vue.js                                           Angular                                     React

组件加载完成        mounted(){}                                    ngOnInit(){ }                           componentDidMount(){}

组件即将卸载       beforeDestroy(){}                            ngOnDestory(){}                      componentWillUnmount(){}

四、复习:前端技术中创建移动App的技术有哪些?

①原生开发:Android下用Java/Kotlin,IOS下用OC/Swift

②H5/WebView:使用浏览器内核打开特定的页面   ------------Vue.js/Mint-UI

③混编开发:H5/WebView+Cordova/PhoneGap  -------------Angular/lonic

④JS Bridge:代码使用JS,使用桥梁转换,运行时是Java或OC ------------ React/RN

⑤Flutter:使用全新的Dart语言,直接在手机GPU上绘图

React中父子组件数据传递的更多相关文章

  1. React中父子组件间的通信问题

    1.https://blog.csdn.net/sinat_17775997/article/details/59103173 (React中父子组件间的通信问题)

  2. vue2.0 父子组件数据传递prop

    vue的一个核心概念就是组件,而组件实例的作用域是孤立的,所以组件之间是不能直接引用其他组件的数据的.极端点举例来说,就是可以在同一个项目中,每一个组件内都可以定义相同名称的数据. data () { ...

  3. 关于vue.js父子组件数据传递

    vue.js中使用props down,events up的原则进行父子组件间的通信,先来记录下props down,看个例子: <div id="app2"> < ...

  4. React中父子组件传值

    一.首先我们先来看父组件向子组件传值 1.1 我们要明白父组件 --> 子组件 是通过props这个属性来传值的 我们来看父组件的代码 import React from 'react'; im ...

  5. react父子组件数据传递

    子传父 1.首先父组件设定一个自定义函数 getChildDatas = (values) => { //...业务代码 } 2.将该函数暴露在子组件的引用上 <Child getChil ...

  6. Vue2.x之父子组件数据传递

    父传子,并且通过fatherEvent接收子组件传过来的值 <template> <div class='father'> <Son :fatherData=" ...

  7. 五、react中父子组件间如何传值

    1.父组件向子组件传递数据:父组件绑定属性值传给子组件,子组件通过this.props()接受. 2.子组件向父组件传递数据:子组件绑定一个方法,方法中通过this.props.父组件方法名(参数)传 ...

  8. React中父组件与子组件之间的数据传递和标准化的思考

    React中父组件与子组件之间的数据传递的的实现大家都可以轻易做到,但对比很多人的实现方法,总是会有或多或少的差异.在一个团队中,这种实现的差异体现了每个人各自的理解的不同,但是反过来思考,一个团队用 ...

  9. 【Vue】Vue中的父子组件通讯以及使用sync同步父子组件数据

    前言: 之前写过一篇文章<在不同场景下Vue组件间的数据交流>,但现在来看,其中关于“父子组件通信”的介绍仍有诸多缺漏或者不当之处, 正好这几天学习了关于用sync修饰符做父子组件数据双向 ...

随机推荐

  1. 安卓微信浏览器中window.location.href失效的问题

    最近接手一微信项目,测试功能时,发现跳转在android手机上不动了.iso系统可以正常跳转的.解决方法: window.location.href = url + '?v=' + (new Date ...

  2. NC使用练习之通达OA-2017版本漏洞复现后续

    利用上一篇通达OA的漏洞环境,练习NC工具的使用. 步骤: 1.本机启动nc.exe监听端口: 确认端口是否成功监听成功: 2.用冰蝎将nc.exe上传至目标机: 3.用命令行在目标机启动nc.exe ...

  3. Java中的小数运算与精度损失

    float.double类型的问题 我们都知道,计算机是使用二进制存储数据的.而平常生活中,大多数情况下我们都是使用的十进制,因此计算机显示给我们看的内容大多数也是十进制的,这就使得很多时候数据需要在 ...

  4. 【手把手教你】win10 虚拟机 VMware Workstation Pro 15下安装redhat 8.0

    安装redhat8.0 和安装Ubuntu 差别不大 可以参考上篇文章:https://www.cnblogs.com/zero-vic/p/11593683.html 但是redhat  8.1 b ...

  5. 初入React源码(一)

    导语 React是我接触的第二个框架,我最初开始接触的是vue,但是并没有深入的理解过vue,然后在工作过程中,我开始使用了React,现在已经觉得React会比vue更加实用,但是这只是个人观点,可 ...

  6. 深入认识CSS的块级元素

    2019独角兽企业重金招聘Python工程师标准>>> 块级元素: 显示在一块内,会自动换行,元素会从上到下垂直排列,各自占一行.每个块级元素默认占一行高度,一行内添加一个块级元素后 ...

  7. JS中由闭包引发内存泄露的深思

    目录 一个存在内存泄露的闭包实例 什么是内存泄露 JS的垃圾回收机制 什么是闭包 什么原因导致了内存泄露 参考 1.一个存在内存泄露的闭包实例 var theThing = null; var rep ...

  8. springboot rabbitmq 找不到队列

    错误报告: org.springframework.amqp.rabbit.listener.BlockingQueueConsumer$DeclarationException: Failed to ...

  9. Elasticsearch系列---Term Vector工具探查数据

    概要 本篇主要介绍一个Term Vector的概念和基本使用方法. term vector是什么? 每次有document数据插入时,elasticsearch除了对document进行正排.倒排索引 ...

  10. 201771010113 李婷华 《面向对象程序设计(Java)》第八周总结

    一.理论知识部分 1.Java为了克服单继承的缺点,Java使用了接口,一个类可以实现一个或多个接口. 2.在Java程序设计语言中,接口不是类,而是对类的一组需求描述,由常量和一组抽象方法组成.接口 ...