首頁 > web前端 > js教程 > 子元件呼叫父元件的方法實例

子元件呼叫父元件的方法實例

小云云
發布: 2018-02-24 09:04:08
原創
1968 人瀏覽過

出於某些目的,最近又開始研究起了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={&#39;pink&#39;} onPress={this.timesReset.bind(this)}>
        <Text style={{textAlign:&#39;center&#39;}}>爹,再给你儿子一次机会!!</Text>
      </TouchableHighlight>
    </View>
    );
  }
}
登入後複製

相關推薦:

Vuejs2.0子元件呼叫父元件的方法

vue使用ref 讓父元件呼叫子元件實例

Vue2.0關於父元件與子元件之間的事件發射與接收

以上是子元件呼叫父元件的方法實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板