前言: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請求代碼。。。。。 }
以上是最近學習所得,若有錯誤煩請指正,不勝感激!學習