這篇文章主要介紹React中受控組件與數(shù)據(jù)共享的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
成都創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比鯉城網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式鯉城網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋鯉城地區(qū)。費(fèi)用合理售后完善,10年實(shí)體公司更值得信賴。具體如下:
在HTML當(dāng)中,像,
例如將input輸入的名字保存在state.name中,并且設(shè)置input顯示的value值為state.name。當(dāng)input中輸入變化時(shí),onChange觸發(fā)updateName函數(shù)更新name值,從而使input中顯示的value發(fā)生變化。當(dāng)點(diǎn)擊提交按鈕時(shí)onClick觸發(fā)submit()方法來阻止默認(rèn)的提交,并打印提示信息:
class ControlledForm extends React.Component{ constructor(props){ super(props); this.state={ name:'' }; this.updateName=this.updateName.bind(this); this.submit=this.submit.bind(this); } updateName(e){ //在調(diào)用函數(shù)時(shí)會(huì)默認(rèn)傳入時(shí)間參數(shù)e this.setState({ name:e.target.value //更新name的值為input中輸入的值 }) } submit(e){ //自己定義點(diǎn)擊submit后的操作 console.log("姓名"+this.state.name+"提交成功"); e.preventDefault(); //阻止表單默認(rèn)提交行為 } render(){ return () } }
使用受控組件使得頁面的數(shù)據(jù)都處于react的控制之下,而且可以對(duì)其數(shù)據(jù)進(jìn)行處理之后再渲染到頁面上。
在React中使用
同理,在React中的
如上,我們需要為每個(gè)受控組件都設(shè)置更新方法onChange,而且每個(gè)組件的更新方法都很類似,這樣看起來很麻煩,我們可以根據(jù)name屬性區(qū)分不同的組件所對(duì)應(yīng)的state值,利用一個(gè)函數(shù)來實(shí)現(xiàn)多個(gè)組件state值的更新:
在setState方法中,通過ES6的語法計(jì)算屬性[],在中括號(hào)中指定要更新的屬性名的表達(dá)式來更新不同的state。例如當(dāng)select調(diào)用updateForm()時(shí),name="sex",value="male",則通過setState將state.sex值設(shè)為male。
當(dāng)兩個(gè)組件要同時(shí)使用一個(gè)變量時(shí),由于state只能被它所定義的組件修改、訪問,因此不能把state賦給某個(gè)組件,而應(yīng)該將state提升至兩個(gè)組件最近的公共父組件,父組件再通過props將值傳遞給子組件,這樣兩個(gè)子組件就都可以訪問了。那么子組件怎么去修改父組件的state呢?子組件通過props屬性來調(diào)用父組件的方法從而修改父組件的state,這樣兩個(gè)組件就通過父組件實(shí)現(xiàn)了對(duì)state的共享。例如父組件Parent的一個(gè)子組件ChildInput負(fù)責(zé)接收用戶的輸入,保存在state.text中,在另一個(gè)子組件ChildShow中顯示用戶的輸入:
class Parent extends React.Component{ constructor(props){ super(props); this.state={ text:'' }; this.updateText=this.updateText.bind(this); } updateText(value){ this.setState({ text:value }) } render(){ return () } } class ChildInput extends React.Component{ constructor(props){ super(props); this.handleChange=this.handleChange.bind(this); } handleChange(e){ //在子組件的方法中調(diào)用父組件的updateInput更新text的值 this.props.updateInput(e.target.value); } render(){ return (
輸入為:{this.props.text}
運(yùn)行結(jié)果如圖:
上例在react中的數(shù)據(jù)流動(dòng)如下:
1、當(dāng)在input中中輸入內(nèi)容時(shí),input內(nèi)容改變onChange觸發(fā)ChildInput組件的handleChange方法,該方法通過this.props調(diào)用父組件updateInput方法并傳遞輸入的內(nèi)容e.target.value。
2、父組件Parent在引用子組件ChildInput時(shí)為其定義updateInput屬性為this.updateText方法,因此觸發(fā)updateText方法,在該方法中接收子組件傳遞的參數(shù)value,并通過setState方法修改state.text的值。
3、當(dāng)state.text值發(fā)生改變時(shí),父組件Parent通過屬性props將值傳遞給子組件ChildInput與ChildShow,引起子組件屬性改變,從而子組件重新渲染頁面內(nèi)容。
以上是“React中受控組件與數(shù)據(jù)共享的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。