React中父子组件数据传递
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中父子组件数据传递的更多相关文章
- React中父子组件间的通信问题
1.https://blog.csdn.net/sinat_17775997/article/details/59103173 (React中父子组件间的通信问题)
- vue2.0 父子组件数据传递prop
vue的一个核心概念就是组件,而组件实例的作用域是孤立的,所以组件之间是不能直接引用其他组件的数据的.极端点举例来说,就是可以在同一个项目中,每一个组件内都可以定义相同名称的数据. data () { ...
- 关于vue.js父子组件数据传递
vue.js中使用props down,events up的原则进行父子组件间的通信,先来记录下props down,看个例子: <div id="app2"> < ...
- React中父子组件传值
一.首先我们先来看父组件向子组件传值 1.1 我们要明白父组件 --> 子组件 是通过props这个属性来传值的 我们来看父组件的代码 import React from 'react'; im ...
- react父子组件数据传递
子传父 1.首先父组件设定一个自定义函数 getChildDatas = (values) => { //...业务代码 } 2.将该函数暴露在子组件的引用上 <Child getChil ...
- Vue2.x之父子组件数据传递
父传子,并且通过fatherEvent接收子组件传过来的值 <template> <div class='father'> <Son :fatherData=" ...
- 五、react中父子组件间如何传值
1.父组件向子组件传递数据:父组件绑定属性值传给子组件,子组件通过this.props()接受. 2.子组件向父组件传递数据:子组件绑定一个方法,方法中通过this.props.父组件方法名(参数)传 ...
- React中父组件与子组件之间的数据传递和标准化的思考
React中父组件与子组件之间的数据传递的的实现大家都可以轻易做到,但对比很多人的实现方法,总是会有或多或少的差异.在一个团队中,这种实现的差异体现了每个人各自的理解的不同,但是反过来思考,一个团队用 ...
- 【Vue】Vue中的父子组件通讯以及使用sync同步父子组件数据
前言: 之前写过一篇文章<在不同场景下Vue组件间的数据交流>,但现在来看,其中关于“父子组件通信”的介绍仍有诸多缺漏或者不当之处, 正好这几天学习了关于用sync修饰符做父子组件数据双向 ...
随机推荐
- 深入理解Java枚举
深入理解Java枚举 重新认识Java枚举 老实说,挺羞愧的,这么久了,一直不知道Java枚举的本质是啥,虽然也在用,但是真不知道它的底层是个啥样的 直到2020年4月28日的晚上20点左右,我才真的 ...
- centos 服务器上部署 xxl-job 通过 feign 访问 eureka 上注册的 service timeout
部署方式 1.使用 jar 包部署 出现的问题 1.通过 feign 调用其他服务,出现超时的问题,该问题不是 ribbon.hystrix 没有配置导致的超时,经过测试,即使配置了也没有作用,该方法 ...
- Libra教程之:来了,你最爱的Move语言
文章目录 Move语言 Move的核心概念 Move交易脚本 Move modules Move resources 写一个Move程序 编写交易脚本 编写自己的Modules Move语言 Move ...
- 痞子衡嵌入式:揭秘i.MXRT1170 eFuse空间访问可靠性的保护策略(冗余与ECC)
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是恩智浦i.MXRT1170的eFuse空间访问可靠性保护策略. 关于i.MXRT系列的eFuse/OTP,痞子衡之前在介绍Boot时写过 ...
- CentOS7虚拟机安装vmtools
直接开始: 在安装vmtools之前,需要先安装两个小部件,否则将安装失败. 下面是步骤: 1.切换为root模式,需要输入root密码,但是不显示. 命令为: su 2.安装gcc 命令为: yum ...
- Angular 7开发环境配置
目录 前言 一.搭建项目 1.安装Angular CLI 2.创建项目 3.集成Element Angular 二.设置路由 1.创建路由模块 2.导入.导出RouterModule类 3 ...
- 【阅读笔记】Ranking Relevance in Yahoo Search (二)—— maching learned ranking
3. MACHINE LEARNED RANKING 1) 完全使用不好的数据去训练模型不可行,因为负面结果不可能覆盖到所有方面: 2) 搜索可以看做是个二分问题,在此实验中,我们使用gradient ...
- Clickhouse 时区转换(下)
Clickhouse 时区转换续—时区参数转换 天天加班,时间不够,主要还是我太懒,流汗,,,,,,另外如果这篇学习笔记超过100阅读量并有评论,我可能半夜也会爬起来更新的. 相信大家看我之前记录的这 ...
- web安全笔记
判断网站是否伪静态 把.html后缀即可或者加.php?id=99 例子:33_99.html 去掉.html和_变成33.php?id=99 即可判断是否伪静态 判断网站是否在win或者linu ...
- golang之array
golang使用array表示固定大小的数组,使用slice表示动态数组. package main import "fmt" func main() { var a = [5]i ...