reac——父组件向子组件传递值,子组件何时能同步获得父组件改变后的值
//这里是父组件的代码:
export default class HeaderCom_son extends React.Component {
constructor(props) {
super(props)
this.state = {
counter: 0,
}
this.x = 0;
this.y = 0;
}
componentWillMount() {
this.timer = setInterval(function () {
this.x++;
this.setState({
counter: this.state.counter + 1
})
this.setState
}.bind(this), 1000);
this.pp = null;
this.init();
} init() {
this.pp = <HeaderCom_son_son x={this.x} y={this.y} counter={this.state.counter}/> //这个this.pp仅运行一次,所以就是仅赋值一次
} render() {
this.y++;
return (
<div>
<div>这是HeaderCom_son</div> ====================
<h3>说明:this.x和this.state.counter都是在一个定义在componentWillMount内的计时器里实现自增</h3>
<p>this.state.counter:{this.state.counter}</p> <p>this.x:{this.x}</p>
====================
<h3>说明:this.y是定义在render方法里实现自增</h3>
<p>this.y:{this.y}</p>
<h3>下面是三个:HeaderCom_son_son组件</h3>
{this.pp} {/* 这个结果永远是初始值0,0,0不会变 */}
<HeaderCom_son_son x={this.x} y={this.y} counter={this.state.counter}/> {/* 这个结果是:子组件的props属性会实时改变,所以能同步获取父组件的改变 */}
<HeaderCom_son_son x={-1} y={-1} counter={-1}/> {/* 这个结果是当然页不会变 */}
</div> );
}
}
//这里是子组件的代码
import React from 'react'; export default class HeaderCom_son_son extends React.Component { render() {
return(
<div>
我是HeaderCom_son_son<br/>
{this.props.x}<br/>
{this.props.y}<br/>
{this.props.counter}
</div>
); }
}
运行293秒后的结果如下图所示:

小总结:
1、this.pp = <HeaderCom_son_son x={this.x} y={this.y} counter={this.state.counter}/>
这个this.pp仅运行一次,所以就是仅赋值一次,并且我发现,this.pp.props和子元素的this.props显示是相同的,还有,即使运行时“等号”右侧的值是对象,this.pp.props的属性值仍是简单数据类型,
所以,如果这个this.pp仅运行一次后期,无论this.pp.props内的属性再如何改变,都不会再传递到子组件上!
2、<HeaderCom_son_son x={this.x} y={this.y} counter={this.state.counter}/> {/* 这个结果是:子组件的props属性会实时改变,所以能同步获取父组件的改变 */}
这个组件的属性都所以能够实时更新,是因为:它在render()方法里,而我们每次只要运行了setState更改都会重新运行render()方法,所以会重新运行:
<HeaderCom_son_son x={this.x} y={this.y} counter={this.state.counter}/>,
也就会重新赋值,所以能实现实时传递给子组件;
但是,如果我们每次更新的并不是state,而仅仅更新其他值,如仅更新this.x,那么这个更新也不能同步传递给子组件,因为不会重新运行render(),也就不会重新赋值;
最后的总结:
归根结底,要判断子组件能否同步获得父组件传递过来的值,就是看父组件更新时,是否会重新运行传递给子组件属性的那句代码;
reac——父组件向子组件传递值,子组件何时能同步获得父组件改变后的值的更多相关文章
- Angular06 组件、模块、父子组件之间的数据传递
1 创建组件 进入到angular项目的根目录,执行如下命令 ng g component test-component 注意:执行完上述命令后在angular项目的src/app文件夹下就会多出一个 ...
- Vue组件注册与数据传递
父子组件创建流程 1.构建父子组件 1.1 全局注册 (1)构建注册子组件 //构建子组件child var child = Vue.extend({ template: '<div>这是 ...
- React中父组件与子组件之间的数据传递和标准化的思考
React中父组件与子组件之间的数据传递的的实现大家都可以轻易做到,但对比很多人的实现方法,总是会有或多或少的差异.在一个团队中,这种实现的差异体现了每个人各自的理解的不同,但是反过来思考,一个团队用 ...
- Vue2.x中的父组件数据传递至子组件
父组件结构 template <template> <div> <v-girl-group :girls="aGirls"></v-gir ...
- vue 父组件中的数据如何传递给子组件
父组件:<template> <div id="app"> <img src="./assets/logo.png"> &l ...
- Vue把父组件的方法传递给子组件调用(评论列表例子)
Vue把父组件的方法传递给子组件调用(评论列表例子) 效果展示: 相关Html: <!DOCTYPE html> <html lang="en"> < ...
- vue父组件与子组件之间的数据传递
父组件向子组件传递数据 父组件用数据绑定:子组件用props接收 <!-- test-vue-model父组件 --> <template> <div> <m ...
- Vue父子组件通信(父级向子级传递数据、子级向父级传递数据、Vue父子组件存储到data数据的访问)
Vue父子组件通信(父级向子级传递数据.子级向父级传递数据.Vue父子组件存储到data数据的访问) 一.父级向子级传递数据[Prop]: ● Prop:子组件在自身标签上,使用自定义的属性来接收外界 ...
- 如果把父组件的数据实时的传递到子组件:用watch
1.在子组件使用watch来监听传递给子组件的数据,然后更新子组件的数据. 2.watch和computed结合使用效果非常好. 参考链接:https://blog.csdn.net/zhouweix ...
随机推荐
- FlowPortal-BPM——数据库交互:创建新接口(类库)—将数据提交给其他程序使用
使用到的是“流程设计”→“自定义插件” 一.创建新类库 (1)新建类库→引用文件 (2)新建ado.net数据访问类(要操作的数据库) (3)右键类库名称→属性→生成→输出→路径:安装目录下UserD ...
- 把一个集合自定转成json字符串
List<CityData> listData =new List<CityData>(); //把一个集合自定转成json字符串. foreach (var city in ...
- Java switch函数
switch()函数中能放置的值为:byte,short,char,int,string,enum类型或者byte,short,char,int的包装类,其中,string类型是java7(含)之后才 ...
- mono for android 百度map binding项目(转)
好丫小子之前发布过百度地图android SDK的mono for android绑定dll,许多朋友看过之后说想理解是怎么绑定的,现我把绑定的代码发出来. 针对2.1.2版本百度地图android ...
- (转)漫谈JVM
漫谈JVM 原文:https://liuzhengyang.github.io/2016/10/05/gossip-jvm/ 背景介绍 JVM已经是Java开发的必备技能了,JVM相当于Java的操作 ...
- JavaScript定时器与执行机制
JavaScript动画中是必须使用到定时器的,这里做一个总结. var label = 'someLable'; console.time(label); console.timeEnd(label ...
- R302指识别开发笔记
一.相关概念 1.存储容量:500枚指纹,地址范围0-499. 2.用户记事本:模块内部为用户开辟了512Bytes的FLASH空间用于存放用户数据该存储空间称为用户记事本,该记事本逻辑上被分成16个 ...
- 下载windows版本apache网页服务器
1.进入apache服务器官网http://httpd.apache.org/,这里我们以下载稳定版的httpd 2.4.25为例,点击download. 2.点击链接Files for Micros ...
- XXX is not in the sudoers file. This incident will be reported 的问题解决方案
不多说,直接上干货! 说的是,这种问题,是出现在ubuntu系统里. root@SparkSingleNode:/usr/local/jdk# pwd /usr/local/jdk root@Spar ...
- JavaScript设计模式-3.原型模式
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...