ES6 では、子コンポーネントが親コンポーネントの使用メソッドを呼び出します。

亚连
リリース: 2018-06-05 09:51:02
オリジナル
2022 人が閲覧しました

ES6 で親コンポーネントを呼び出すサブコンポーネントを実装するにはどうすればよいですか?次に、ES6 で子コンポーネントが親コンポーネントを呼び出す方法についての記事を共有します。お役に立てれば幸いです。

最近、ある目的で RN を再度勉強し始めて、チュートリアルを見て段階的に学習しているときに、最近、親子コンポーネントのメソッド呼び出しの問題に遭遇しました。

私は長い間 Baidu でこの質問をしてきました。JS の ES6 構文では、クラスを使用してコンポーネントを作成すると、子コンポーネントが親コンポーネントのメソッドを呼び出すときにシミュレーターがエラーを報告し続けます。

私が見たビデオはes5構文に基づいたコードなので、構文が少し異なります。

es5の構文ではメソッドのthisはRNがやってくれているので動画の例通りの効果が得られますが、es6では自分で書く必要があるようです。 。

具体的な書き方は、 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>
    );
  }
}
ログイン後にコピー

以上は皆さんのためにまとめたもので、今後皆さんのお役に立てれば幸いです。

関連記事:

ExtJs を使用して Echarts を統合する方法 (詳細なチュートリアル)

angularJS で div メソッドを動的に追加および削除する方法

React の要素、コンポーネント、インスタンス、ノードの詳細な解釈

以上がES6 では、子コンポーネントが親コンポーネントの使用メソッドを呼び出します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!