ES6下子組件調(diào)用父組件的方法(推薦)
出于某些目的,最近又開始研究起了RN,看著教程一步步的學(xué)習(xí),在最近卻是碰到了一個問題,那就是父子組件的方法調(diào)用的問題。
這個問題我百度了很久,JS的ES6語法下,用class創(chuàng)建組件,子組件調(diào)用父組件方法模擬器不斷報錯。
因為我看的視頻是基于es5的語法來實現(xiàn)的代碼,所以語法有些不同。
es5的語法下,方法的this都是RN已經(jīng)幫我們處理好了的,所以按照視頻中的示例是可以達成效果的,但是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下子組件調(diào)用父組件的方法(推薦)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
javascript for-in有序遍歷json數(shù)據(jù)并探討各個瀏覽器差異
這篇文章主要介紹了javascript for-in有序遍歷json數(shù)據(jù)并探討各個瀏覽器差異的相關(guān)資料,需要的朋友可以參考下2015-11-11
JavaScript實現(xiàn)定時器循環(huán)展示數(shù)組
這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)定時器循環(huán)展示數(shù)組,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-09-09
Javascript下IE與Firefox下的差異兼容寫法總結(jié)

