解決React報錯`value` prop on `input` should not be null
總覽
當我們把一個input的初始值設(shè)置為null或者覆蓋初始值設(shè)置為null時,會產(chǎn)生"valueprop on input should not be null"警告。比如說,初始值來自于空的API響應(yīng)??梢允褂靡粋€回退值來解決這個問題。

這里有個例子來展示錯誤是如何發(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>
);
}
上述代碼的問題在于,我們?yōu)?code>input表單的value屬性設(shè)置為null,這是不被允許的。
你也可能從遠程API獲取你的input表單的值,并將其設(shè)置為null。
回退值
為了解決該問題,我們可以通過提供回退值,來確保永遠不會為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變量的值初始化為一個空字符串,而不是null。
這樣就可以擺脫警告,除非在你代碼的其他地方將state變量設(shè)置為null。
我們使用邏輯與(||)操作符,如果操作符左側(cè)的為假值(比如說null),則返回其右側(cè)的值。這可以幫助我們確保input表單的value屬性永遠不會被設(shè)置為null。
defaultValue
如果你借助refs使用不受控制的input表單,請不要在input元素上設(shè)置value屬性,使用defaultValue來代替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表單上并沒有設(shè)置onChange或者value屬性。
你可以使用defaultValue屬性來為不受控制的input傳遞初始值。然而,這一步驟不是必要的,如果你不想設(shè)置初始值,你可以省略該屬性。
當使用不受控制的input表單時,我們使用ref來訪問input元素。每當用戶點擊例子中的按鈕時,不受控制的input 的值都會被記錄下來。
你不應(yīng)該為不受控制的input設(shè)置value屬性,因為這將使input表單不可變,你將無法在其中輸入。
翻譯原文鏈接:bobbyhadz.com/blog/react-…
以上就是解決React報錯`value` prop on `input` should not be null的詳細內(nèi)容,更多關(guān)于React 報錯解決value input的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
淺談React的React.FC與React.Component的使用
本文主要介紹了React的React.FC與React.Component的使用,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09
react.js實現(xiàn)頁面登錄跳轉(zhuǎn)示例
本文主要介紹了react.js實現(xiàn)頁面登錄跳轉(zhuǎn)示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧2023-01-01
react+antd實現(xiàn)動態(tài)編輯表格數(shù)據(jù)
這篇文章主要為大家詳細介紹了react+antd實現(xiàn)動態(tài)編輯表格數(shù)據(jù),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-08-08
React在Dva項目中創(chuàng)建并引用頁面局部組件的方式
這篇文章主要介紹了React在Dva項目中創(chuàng)建并引用頁面局部組件的方式,本文給大家介紹的非常詳細,對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07

