出於某些目的,最近又開始研究起了RN,看著教程一步步的學習,在最近卻是碰到了一個問題,那就是父子組件的方法調用的問題。這個問題我百度了很久,JS的ES6語法下,用class建立元件,子元件呼叫父元件方法模擬器不斷報錯。本文主要為大家分享一篇ES6下子元件呼叫父元件的方法。希望能幫助大家。
因為我看的影片是基於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中文網其他相關文章!