明霞山资源网 Design By www.htccd.com
出于某些目的,最近又开始研究起了RN,看着教程一步步的学习,在最近却是碰到了一个问题,那就是父子组件的方法调用的问题。
这个问题我百度了很久,JS的ES6语法下,用class创建组件,子组件调用父组件方法模拟器不断报错。
因为我看的视频是基于es5的语法来实现的代码,所以语法有些不同。
es5的语法下,方法的this都是RN已经帮我们处理好了的,所以按照视频中的示例是可以达成效果的,但是es6貌似是要自己写的。。
具体的写法就是在constructor中添加 this.xxxxx = this.xxxxx.bind(this);
或者在子组件绑定的时候就写this.xxxxx.bind(this) .
这里就不多讲了,下面上代码,以供需要的人参考。
export default class TestPrj extends Component {
constructor(props){
super(props);
this.timesReset = this.timesReset.bind(this);
this.state = {timex:2};
}
timesReset(){
this.setState({
timex:0
});
}
render() {
return(
<View style={styles.container}>
<Son ref="Son1" timex={this.state.timex} timesReset={this.timesReset}/>
//或者<Son ref="Son1" timex={this.state.timex} timesReset={this.timesReset.bind(this)}/>
</View>
);
}
}
class Son extends Component{
constructor(props){
super(props);
this.state = {times:this.props.timex};
}
componentWillReceiveProps(props){
console.log(this.props);
this.setState({
times:props.timex
})
}
timesReset(){
this.props.timesReset();
}
render(){
return(
<View style={styles.container}>
<Text style={styles.instructions}>
儿子:虽然你揍了我 {this.state.times} 次,但是我 永 不 屈 服!!
</Text>
<TouchableHighlight style={styles.btn} underlayColor={'pink'} onPress={this.timesReset.bind(this)}>
<Text style={{textAlign:'center'}}>爹,再给你儿子一次机会!!</Text>
</TouchableHighlight>
</View>
);
}
}
以上这篇ES6下子组件调用父组件的方法(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
标签:
父组件调用子组件方法
明霞山资源网 Design By www.htccd.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
明霞山资源网 Design By www.htccd.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。