解決React報(bào)錯(cuò)`value` prop on `input` should not be null
總覽
當(dāng)我們把一個(gè)input
的初始值設(shè)置為null
或者覆蓋初始值設(shè)置為null
時(shí),會(huì)產(chǎn)生"value
prop on input
should not be null"警告。比如說(shuō),初始值來(lái)自于空的API響應(yīng)。可以使用一個(gè)回退值來(lái)解決這個(gè)問(wèn)題。
這里有個(gè)例子來(lái)展示錯(cuò)誤是如何發(fā)生的。
export default function App() { // ?? Warning: `value` prop on `input` should not be null. // Consider using an empty string to clear the component or `undefined` for uncontrolled components. return ( <div> <input value={null} /> </div> ); }
上述代碼的問(wèn)題在于,我們?yōu)?code>input表單的value
屬性設(shè)置為null
,這是不被允許的。
你也可能從遠(yuǎn)程API獲取你的input
表單的值,并將其設(shè)置為null
。
回退值
為了解決該問(wèn)題,我們可以通過(guò)提供回退值,來(lái)確保永遠(yuǎn)不會(huì)為input
表單的value
屬性設(shè)置null
。
import {useState} from 'react'; const App = () => { // ??? pass empty string as initial value const [message, setMessage] = useState(''); const handleChange = event => { setMessage(event.target.value); }; // ? use fallback, e.g. // value={message || ''} return ( <div> <input type="text" id="message" name="message" onChange={handleChange} value={message || ''} /> </div> ); }; export default App;
我們把state
變量的值初始化為一個(gè)空字符串,而不是null
。
這樣就可以擺脫警告,除非在你代碼的其他地方將state
變量設(shè)置為null
。
我們使用邏輯與(||)操作符,如果操作符左側(cè)的為假值(比如說(shuō)null
),則返回其右側(cè)的值。這可以幫助我們確保input
表單的value
屬性永遠(yuǎn)不會(huì)被設(shè)置為null
。
defaultValue
如果你借助refs
使用不受控制的input
表單,請(qǐng)不要在input
元素上設(shè)置value
屬性,使用defaultValue
來(lái)代替value
屬性。
import {useRef} from 'react'; const App = () => { const inputRef = useRef(null); function handleClick() { console.log(inputRef.current.value); } return ( <div> <input ref={inputRef} type="text" id="message" name="message" defaultValue="Initial value" /> <button onClick={handleClick}>Log message</button> </div> ); }; export default App;
上述示例使用了不受控制的input
。注意input
表單上并沒(méi)有設(shè)置onChange
或者value
屬性。
你可以使用defaultValue
屬性來(lái)為不受控制的input
傳遞初始值。然而,這一步驟不是必要的,如果你不想設(shè)置初始值,你可以省略該屬性。
當(dāng)使用不受控制的input
表單時(shí),我們使用ref
來(lái)訪問(wèn)input
元素。每當(dāng)用戶點(diǎn)擊例子中的按鈕時(shí),不受控制的input
的值都會(huì)被記錄下來(lái)。
你不應(yīng)該為不受控制的input
設(shè)置value
屬性,因?yàn)檫@將使input
表單不可變,你將無(wú)法在其中輸入。
翻譯原文鏈接:bobbyhadz.com/blog/react-…
以上就是解決React報(bào)錯(cuò)`value` prop on `input` should not be null的詳細(xì)內(nèi)容,更多關(guān)于React 報(bào)錯(cuò)解決value input的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
react?hooks?計(jì)數(shù)器實(shí)現(xiàn)代碼
這篇文章主要介紹了react?hooks計(jì)數(shù)器實(shí)現(xiàn)代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-08-08適用于React?Native?旋轉(zhuǎn)木馬應(yīng)用程序介紹
這篇文章主要介紹了適用于React?Native?旋轉(zhuǎn)木馬應(yīng)用程序介紹,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10React?Native?中實(shí)現(xiàn)倒計(jì)時(shí)功能
這篇文章主要介紹了React?Native中實(shí)現(xiàn)倒計(jì)時(shí)功能示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08