ホームページ >ウェブフロントエンド >jsチュートリアル >React の親コンポーネントと子コンポーネント間の値の転送の問題の分析

React の親コンポーネントと子コンポーネント間の値の転送の問題の分析

不言
不言オリジナル
2018-07-11 16:01:432424ブラウズ

この記事では、主に反応する親コンポーネントと子コンポーネント間の値の転送の問題の分析を紹介します。これには、必要な友達が参照できるように共有します。

親コンポーネントは子コンポーネントに渡されます。中心となるアイデアは、親コンポーネントの状態を子コンポーネントに渡すことです

父组件代码:
class Father extends React.Component {
  constructor(props){
    super(props);
    // 父组件的state
    this.state = {
      menu:[]
    }
  }
  componentDidMount() {
      // 这里可以发ajax请求  去后端请求数据   通过setState将值保存到自己的state中
      // 假定data为后端请求回来的数据
      var data = [];
      this.setState({
          menu: data
      })
  }
  render() {
      return (
          {this.state.menu.map(function (data) {
            return <Children data={data} key={data.key}/>
          })}
      )
  }
}
export default Father;
子组件代码:
class Children extends React.Component {
    render(){
        // 这里的data就是父组件传递过来的值
        var data = this.props.data;
        return(
            <Col md={ 3 }>
                <FormGroup className="p-b">
                  <label className="input">
                    // 这里就可以通过将data中的值渲染到子组件中
                    <input id={data.key} type="text" value={data.value}/>
                    <em className="fa fa-check"></em>{data.value}
                  </label>
                </FormGroup>
            </Col>
        )
    }
}

上記は、親コンポーネントが子コンポーネントに値を渡すことです

現在のプロジェクト開発プロセスでは、ほとんどの子コンポーネントは次のようなデータ操作を必要とします。 input 入力、チェックボックスの選択、選択解除など。この場合、サブコンポーネントのデータを親コンポーネントに返す必要があります。redux を使用すると、ストアを通じてデータを一元的に管理および分散できます。反応単独でも実現できます

サブコンポーネント 親コンポーネントに値を渡す:

一般的な考え方は、親コンポーネントと子コンポーネントが親コンポーネントの状態を共同で管理するというものです。子コンポーネントを呼び出し、子コンポーネントは onChange を通じて親コンポーネントの状態にデータを返します

父组件代码:
class Father extends React.Component {
  constructor(props){
    super(props);
    // 父组件的state
    this.state = {
      menu:[]
    }
  }
  componentDidMount() {
      // 这里可以发ajax请求  去后端请求数据   通过setState将值保存到自己的state中
      // 假定data为后端请求回来的数据
      var data = [];
      this.setState({
          menu: data
      })
  }
  // 子组件触发   参数就是子组件回传回来的一些数据
  ChildrenFunc(data,value,key){
    // 拿到当前组件的state
    let menu = this.state.menu;
    // 遍历当前state,遍历过程中可以对state中的值进行修改
    for(let i = 0; i < menu.length; i++){
      if(key == menu[i].key){
        menu[i].value = data;
      }
    };
    // 将修改之后的值保存到当前组件的state中
    this.setState({
      menu: menu
    });
  }
  render() {
      return (
          {this.state.menu.map(function (data) {
            // onUpdata方法就是子组件状态改变时就会调用这个函数,通过这个函数子组件就会触发父组件的ChildrenFunc方法,从而达到修改state的功能
            return <Children data={data} key={data.key} onUpdata={(data,value,position) => {$this.ChildrenFunc(data,value,position)}}/>
          })}
      )
  }
}
export default Father;

子组件代码:
class Children extends React.Component {
    // 子组件状态改变就会触发父组件传递过来的onUpdata方法,可以进行一系列的传值,比如将输入值传递回去等
    ChildrenChange(event,value,position){
        this.props.onUpdata(event.target.value,value,position);
    }
    render(){
        // 这里的data就是父组件传递过来的值
        var data = this.props.data;
        return(
            <Col md={ 3 }>
                <FormGroup className="p-b">
                  <label className="input">
                    // 这里就可以通过将data中的值渲染到子组件中
                    <input id={data.key} onChange={(event) => {this.ChildrenChange(event,"end",data.key)}} type="text" value={data.value}/>
                    <em className="fa fa-check"></em>{data.value}
                  </label>
                </FormGroup>
            </Col>
        )
    }
}

以上です。親コンポーネントに値を渡す子コンポーネントの実装メソッド (データの送信など) を実行できます。例:
父组件中提交数据:
addData(){
    // 获取state
    let menu = this.state.menu;
    // 遍历state   将我们要的数据取出来
    var newArray = [];
    for(let i = 0; i < menu.length; i++){
      if(menu[i].key == "某些我们需要的值"){
        newArray.push(menu[i].value);
      }
    };
    // 提交时的参数
    var data = {
        id: "xxxx",
        menu: newArray.join(",")
    }
    // 提交的ajax请求代码。。。。。
}

以上がこの記事の全内容です。その他の関連コンテンツについては、PHP に注目してください。中国語のサイトです!

関連する推奨事項:

Vue+Mock.js でフロントエンド独立開発環境を構築する方法


vue ベースのダイアログ プラグイン、art-dialog-vue2.0 のリリース内容。 js

以上がReact の親コンポーネントと子コンポーネント間の値の転送の問題の分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。