这次给大家带来在ES6中子组件怎么调用父组件,在ES6中子组件调用父组件的注意事项有哪些,下面就是实战案例,一起来看一下。
出于某些目的,最近又开始研究起了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>
);
}
}相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
LimeSurvey是一款问卷调查管理系统,具有问卷的设计、修改、发布、回收和统计等多项功能,集成了调查程序开发、调查问卷的发布以及数据收集等功能,使用它,用户不必了解这些功能的编程细节。 LimeSurvey 3.14.2 中文版 更新日志:2018-08-07 -修正问题#13878:向用户组发送电子邮件-显示问题; -修正问题#13902:LimeSurvey尝试在编辑问题时更新响
154
以上就是在ES6中子组件怎么调用父组件的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号