ホームページ  >  記事  >  ウェブフロントエンド  >  React コンポーネント通信の概要 (コード例)

React コンポーネント通信の概要 (コード例)

不言
不言転載
2019-04-03 09:43:491951ブラウズ

この記事では、React コンポーネント通信の概要 (コード例) を紹介します。一定の参考価値があります。必要な友人は参照してください。お役に立てば幸いです。

私は最近、React フレームワークを独学で自由に勉強できるようになりました。独学プロセス中に発生したすべての問題と経験がここに記録されます。React フレームワークを学習している学生に役立つことを願っています。ああ、コードについて話しましょう。
親から子への最初のパス:

import React, { Component } from 'react';
import Com1 from './componments/com1'

class App extends Component {
  constructor(props){
    super(props)
    this.state = {
      arr: [{
          "userName": "fangMing", "text": "123333", "result": true
      }, {
          "userName": "zhangSan", "text": "345555", "result": false
      }, {
          "userName": "liSi", "text": "567777", "result": true
      }, {
          "userName": "wangWu", "text": "789999", "result": true
      },]
    };
    this.foo = "我来自父组件"  //这个也是父传子方法,可能初学者有点迷,刚开始我也用来和arr = {this.state.arr}做区分
  };
  render() {
    return (
      <div>
        <header>
          <img  alt="React コンポーネント通信の概要 (コード例)" >                    
        </header>
        <com1></com1>
      </div>
    );
  }
}
export default App;

子コンポーネント:

import React, { Component } from 'react';

class Ele extends Component{
    constructor(props){
       super(props)  
    };
    render(){
        return (
           <div>
               <h1>Hello, {this.props.age}</h1>
               <p>{this.props.fn}</p>
               <ul>
                    {
                        this.props.arr.map(item => { //这个地方通过this.props.arr接收到父组件传过来的arr,然后在{}里面进行js的循环
                            return (
                                <li>
                                    {item.userName} 评论是:{item.text}
                                </li>
                            )
                        })
                    }
                </ul>
           </div>
        );
    };
}

export default Ele;

結果は次のようになります:

React コンポーネント通信の概要 (コード例)

上は親です 子に値を渡す主な方法は、props を使用して値を渡すことです。子から親への受け渡しを見てみましょう。

子から親への受け渡し:
まずは子コンポーネント:

import React, { Component } from 'react';

class Ele extends Component{
    constructor(props){
       super(props);
       this.state = ({
            childText: "我来自子组件"
       })  
    };
    clickFun(text) {  //定义触发的方法
        this.props.pfn(text)//这个地方把值传递给了props的事件当中
    }
    render(){
        return (
           <div>               
                {/* 通过事件进行传值,如果想得到event,可以在参数最后加一个event,
                这个地方还是要强调,this,this,this */}
                <button>
                    传值
                </button>
           </div>
        );
    };
}

export default Ele;

親コンポーネント:

import React, { Component } from 'react';
import Com1 from './componments/com1'

class App extends Component {
  constructor(props){
    super(props)
    this.state = {
      parentText: "现在是父组件",     
  };
  fn(data) {
    this.setState({
        parentText: data //把父组件中的parentText替换为子组件传递的值
    },() =>{
       console.log(this.state.parentText);//setState是异步操作,但是我们可以在它的回调函数里面进行操作
    });
  };
  render() {
    return (
      <div>
        <com1></com1> {/*通过绑定事件进行值的运算,这个地方一定要记得.bind(this),不然会报错,切记切记,因为通过事件传递的时候this的指向已经改变 */}
        <p>text is {this.state.parentText}</p>
      </div>
    );
  }
}
export default App;

上記は親コンポーネントと子コンポーネント間の値の受け渡し方法です。間違いがあれば修正してください
兄弟コンポーネント間の値の転送についてはまだ学習していません。兄弟コンポーネント間の値の転送について学習したら更新します

#[関連する推奨事項:

React ビデオ チュートリアル]

以上がReact コンポーネント通信の概要 (コード例)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はsegmentfault.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。