這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)使用React如何實(shí)現(xiàn)父子組件通信,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
創(chuàng)新互聯(lián)主要從事網(wǎng)站建設(shè)、網(wǎng)站制作、網(wǎng)頁設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)吉利,10余年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):18982081108
1.父組件與子組件間的通信。
在 React 中,父組件可以向子組件通過傳 props 的方式,向子組件進(jìn)行通訊。
父組件 App.js
import React, { Component } from 'react'; import './App.css'; import Child from './child' class App extends Component { constructor(props){ super(props); this.state={ msg:'父類的消息', name:'John', age:99 } } callback=(msg,name,age)=>{ // setState方法,修改msg的值,值是由child里面?zhèn)鬟^來的 this.setState({msg}); this.setState({name}); this.setState({age}); } render() { return ( <div className="App"> <p> Message: {this.state.msg}</p> <Child callback={this.callback} age={this.state.age} name={this.state.name}></Child> </div> ); } } export default App;
父組件中,state里面有三個(gè)屬性,分別是msg,name和age,在子組件child中,如果想拿到父組件里面的屬性,就需要通過props傳遞。
在 <Child></Child> 標(biāo)簽里面添加
name={this.state.name} age={this.state.age}
寫成
<Child name={this.state.name} age={this.state.age}></Child>
name和age分別是你要傳遞的屬性。
子組件 Child
import React from "react"; class Child extends React.Component{ constructor(props){ super(props); this.state={ name:'Andy', age:31, msg:"來自子類的消息" } } change=()=>{ this.props.callback(this.state.msg,this.state.name,this.state.age); } render(){ return( <div> <div>{this.props.name}</div> <div>{this.props.age}</div> <button onClick={this.change}>點(diǎn)擊</button> </div> ) } } export default Child;
在子組件中,通過 {this.props.name} {this.props.age}就能拿到父組件里面的數(shù)據(jù)。
呈現(xiàn)在頁面上的就是這個(gè)樣子。
其中 John,99均來自于父組件App.js
2.子組件向父組件通信
子組件向父組件通訊,同樣也需要父組件向子組件傳遞 props 進(jìn)行通訊,只是父組件傳遞的,是作用域?yàn)楦附M件自身的函數(shù),子組件調(diào)用該函數(shù),將子組件想要傳遞的信息,作為參數(shù),傳遞到父組件的作用域中。
上面例子中,在子組件Child中綁定了onClick事件。 調(diào)用this.change方法。
注意change函數(shù)采用了箭頭函數(shù)的寫法 change=()=>{},目的是為了改變this的指向。使得在函數(shù)單獨(dú)調(diào)用的時(shí)候,函數(shù)內(nèi)部的this依然指向child組件
如果不使用箭頭函數(shù),而是采用普通的寫法
change(){ }
則需要在 constructor中綁定this,
this.change=this.change.bind(this)
或者在onClick方法中綁定this,
onClick={this.change=this.change.bind(this)}
在change方法中,通過props發(fā)送出去一個(gè)方法,比如說叫callback方法,父組件中去接收這個(gè)方法,callback={this.callback},然后在自身的callback函數(shù)中進(jìn)行一些列操作。
上述就是小編為大家分享的使用React如何實(shí)現(xiàn)父子組件通信了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
新聞名稱:使用React如何實(shí)現(xiàn)父子組件通信
文章位置:http://bm7419.com/article22/pciicc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供Google、企業(yè)建站、用戶體驗(yàn)、虛擬主機(jī)、移動(dòng)網(wǎng)站建設(shè)、域名注冊
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)