這次帶給大家在ES6中子元件怎麼呼叫父元件,在ES6中子元件呼叫父元件的注意事項有哪些,下面就是實戰案例,一起來看一下。
出於某些目的,最近又開始研究起了RN,看著教程一步步的學習,在最近卻是碰到了一個問題,那就是父子組件的方法調用的問題。
這個問題我百度了很久,JS的ES6語法下,用class建立元件,子元件呼叫父元件方法模擬器不斷報錯。
因為我看的影片是基於es5的語法來實現的程式碼,所以語法有些不同。
es5的語法下,方法的this都是RN已經幫我們處理好了的,所以按照影片中的範例是可以達成效果的,但是es6貌似是要自己寫的。 。
具體的寫法就是在constructor中加入this.xxxxx = this.xxxxx.bind(this);
#或是在子元件綁定的時候就寫this.xxxxx.bind(this ) .
這裡就不多講了,下面上程式碼,以供需要的人參考。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 | 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}/>
</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中文網其它相關文章!
推薦閱讀:
JS常用的訊息方塊有哪些
js隨機產生6位元隨機數字
js動態建立標籤以及設定屬性的方法
#
以上是在ES6中子元件怎麼呼叫父元件的詳細內容。更多資訊請關注PHP中文網其他相關文章!