ES6下子组件调用父组件的方法(推荐)
2018-02-23 14:19
621 查看
出于某些目的,最近又开始研究起了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下子组件调用父组件的方法(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- ES6下子组件调用父组件方法
- 安卓四大组件之二#1-Service的创建,生命周期以及动态调用Service里的方法 推荐
- [转]关于Microsoft.Office.Interop组件接口的调用方法
- 父组件中调用子组件的方法和属性
- vue 使用ref 让父组件调用子组件的方法
- 常用js,css文件统一加载方法(推荐) 并在加载之后调用回调函数
- GridView等组件绑定后台数据源列的绑定方法,onclick方法调用中含有Eval绑定如何调用js方法
- "对COM 组件的调用返回了错误 HRESULT E_FAIL"的解决方法
- bbossgroups-3.1 发布,支持组件方法异步调用
- a 中调用js的几种方法整理及使用推荐
- 通过java反射机制动态调用某方法的总结(推荐)
- 不使用第三方组件,只调用COM,导出EXECL,但只装OFFICE2007,不装2003,直接强制引用动态库的方法
- "对COM 组件的调用返回了错误 HRESULT E_FAIL"的解决方法
- php调用MySQL存储过程的方法集合(推荐)
- 在APP中嵌套H5页面,点击页面上的按钮调用app的组件方法
- JS函数的定义与调用方法推荐
- react 兄弟组件如何调用对方的方法示例
- vue中父组件调用子组件的方法和属性
- Android实现Activity、Service与Broadcaster三大组件之间互相调用的方法详解
- Titanium中调用ios组件时语言不是本地化的解决方法