react父子組件之間傳值簡述(近期學習心得)

前言:react中的數據流動有很好的解決方案:redux,可是redux對於初學者來講學習曲線比較陡,而且在小型項目不太適用,開發維護成本都比較高,因此這裏我只說單獨用react的狀況下組件之間傳值的用法,自學的,有不足煩請大神指正。

父組件傳遞給子組件:
核心思路就是將父組件中的state傳遞給子組件react

父組件代碼:
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>
        )
    }
}

以上就是父組件傳值給子組件ajax

如今的項目開發過程當中,大多數的子組件是須要有一些數據上的操做的,好比input中的輸入、checkbox的選中與取消選中等,這樣的狀況下就須要將子組件的數據回傳給父組件,應用redux的話,能夠經過store統一管理分發數據,單獨用react也是能夠實現的redux

子組件傳值給父組件:
整體思路就是父組件與子組件統一管理父組件中的state,父組件將state傳遞給子組件,子組件經過onChange將數據回傳給父組件的state後端

父組件代碼:
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>
        )
    }
}

以上就是子組件傳值給父組件的實現方式,父組件中更進一步操做(例如提交數據)就能夠經過自身state中的值來進行提交
例如:函數

父組件中提交數據:
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請求代碼。。。。。
}

以上是最近學習所得,若有錯誤煩請指正,不勝感激!學習

相關文章
相關標籤/搜索