react中value與defaultValue的區(qū)別及說明
react中value與defaultValue的區(qū)別
在日常開發(fā)的過程中,我們經(jīng)常會使用input輸入框,有時會需要使用value綁定數(shù)據(jù),針對這一點(diǎn),react提出了一個概念,分為了約束性組件和非約束性組件。
之前正常使用的時候我們只需要這樣寫:
<input value={綁定的數(shù)據(jù)} type='text'/>在react中這樣的寫法會出現(xiàn)一個錯誤,提示你應(yīng)該使用onChange來監(jiān)聽這個input或者使用defaultValue來綁定數(shù)據(jù)。這樣可以消除這個錯誤。
那么當(dāng)使用defaultValue的時候:
<input ?defaultValue={綁定的數(shù)據(jù)} type='text'/>這個時候就是一個非約束性組件,其實(shí)就是原生DOM中的value屬性,這樣寫出來的組件,其value值就是用戶輸入的內(nèi)容,和react沒有關(guān)系,完全不管輸入的過程。
當(dāng)使用onChange的時候:
<input value={綁定的數(shù)據(jù)} type="text" onChange={this.handleChange}/>這個時候就是一個約束性組件,這里value不再是寫死的值,他是你所綁定的數(shù)據(jù),綁定的數(shù)據(jù)是由this.handleChange負(fù)責(zé)管理的。這個時候?qū)嶋H上input的value根本不是用戶輸入的內(nèi)容。而是onChange事件觸發(fā)之后,由this.state導(dǎo)致了一次重新渲染,不過react會優(yōu)化這個過程。
注意:
如果在使用input時只需要獲取model里的值時,使用defaultValue就可以了。
如果需要獲取model的值并且還需要改變它的時候,就需要使用value結(jié)合onChange事件就可以了。
react select標(biāo)簽defaultValue和value踩坑日記
最近在寫react項(xiàng)目,需要設(shè)置下拉框默認(rèn)值.
第一版本
使用defaultValue,發(fā)現(xiàn)刷新頁面,數(shù)據(jù)錯誤
分析:defaultValue只在頁面掛載時渲染一次,后續(xù)數(shù)據(jù)發(fā)生變化,不再重新渲染
<div className="month">
? ? <select defaultValue="dayjs().get("month")" onChange={(e) => onChange(e)}>
? ? ? ? {months.map(month => <option key={month} value={month} >{month}</option>)}
? ? </select>
? ? 月
</div>第二版
修改為value,點(diǎn)擊select,發(fā)現(xiàn)數(shù)據(jù)更新了,但頁面不更新;
分析:value需要接收一個動態(tài)數(shù)據(jù),dayjs().get(“month”)是一個死值。
<div className="month">
? ? <select value="dayjs().get("month")" onChange={(e) => onChange(e)}>
? ? ? ? {months.map(month => <option key={month} value={month} >{month}</option>)}
? ? </select>
? ? 月
</div>第三版
使用value綁定動態(tài)數(shù)據(jù),且綁定onChange監(jiān)聽函數(shù)
? ? const onChange = (e: React.ChangeEvent<HTMLSelectElement>) => {
? ? ? ? let date = e.target.value
? ? ? ? if (date.length === 4) {
? ? ? ? ? ? setSelectDate({
? ? ? ? ? ? ? ? year: date,
? ? ? ? ? ? ? ? month: selectDate.month
? ? ? ? ? ? })
? ? ? ? } else {
? ? ? ? ? ? setSelectDate({
? ? ? ? ? ? ? ? year: selectDate.year,
? ? ? ? ? ? ? ? month: date
? ? ? ? ? ? })
? ? ? ? }
? ? }
<div className="month">
? ? <select value={selectDate.month} onChange={(e) => onChange(e)}>
? ? ? ? {months.map(month => <option key={month} value={month} >{month}</option>)}
? ? </select>
? ? 月
</div>總結(jié)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
React 事件綁定的實(shí)現(xiàn)及區(qū)別
事件綁定也是其中一部分內(nèi)容,通過事件委托和事件合成,React 在內(nèi)部對事件進(jìn)行優(yōu)化和處理,減少了事件處理函數(shù)的調(diào)用次數(shù),從而提升了性能,本文主要介紹了React事件綁定的實(shí)現(xiàn)及區(qū)別,感興趣的可以了解一下2024-03-03
React文件名和目錄規(guī)范最佳實(shí)踐記錄(總結(jié)篇)
React在使用時非常靈活,如果沒有一個規(guī)范約束項(xiàng)目,在開發(fā)過程中會非常混亂,本文將介紹幾個優(yōu)秀的規(guī)范,介紹文件名和目錄前,需要先簡述一下幾種通用的類型,用來區(qū)分文件的功能,感興趣的朋友一起看看吧2022-05-05
React獲取Java后臺文件流并下載Excel文件流程解析
這篇文章主要介紹了React獲取Java后臺文件流下載Excel文件,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-06-06
React/Redux應(yīng)用使用Async/Await的方法
本篇文章主要介紹了React/Redux應(yīng)用使用Async/Await的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-11-11
antd之RangePicker設(shè)置默認(rèn)值方式
這篇文章主要介紹了antd之RangePicker設(shè)置默認(rèn)值方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12
React+EggJs實(shí)現(xiàn)斷點(diǎn)續(xù)傳的示例代碼
這篇文章主要介紹了React+EggJs實(shí)現(xiàn)斷點(diǎn)續(xù)傳的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07

