react component changing uncontrolled input報錯解決
總覽
當input的值被初始化為undefined,但后來又變更為一個不同的值時,會產(chǎn)生"A component is changing an uncontrolled input to be controlled"警告。為了解決該問題,將input的值初始化為空字符串。比如說,value={message || ''} 。

這里有個例子來展示錯誤是如何發(fā)生的。
import {useState} from 'react';
const App = () => {
// ??? didn't provide an initial value for message
const [message, setMessage] = useState();
const handleChange = event => {
setMessage(event.target.value);
};
return (
<div>
<input
type="text"
id="message"
name="message"
onChange={handleChange}
value={message}
/>
</div>
);
};
export default App;
上面代碼的問題在于,message變量被初始化為undefined,因為我們沒有在useState鉤子中為其傳遞初始值。
備用值
解決該錯誤的一種方式是,如果input的值為undefined,那么就提供一個備用值。
import {useState} from 'react';
const App = () => {
const [message, setMessage] = useState();
const handleChange = event => {
setMessage(event.target.value);
};
// ??? value={message || ''}
return (
<div>
<input
type="text"
id="message"
name="message"
onChange={handleChange}
value={message || ''}
/>
</div>
);
};
export default App;
我們使用邏輯與(||)操作符,如果操作符左側(cè)的為假值(比如說undefined),則返回其右側(cè)的值。
如果message變量的值存儲為undefined,我們將空字符串作為備用值進行返回。
useState
另一種解決方案是,在useState鉤子中為state變量傳遞初始值。
import {useState} from 'react';
const App = () => {
// ??? pass an initial value to the useState hook
const [message, setMessage] = useState('');
const handleChange = event => {
setMessage(event.target.value);
};
return (
<div>
<input
type="text"
id="message"
name="message"
onChange={handleChange}
value={message}
/>
</div>
);
};
export default App;
在useState鉤子中傳遞初始值可以避免警告,因為此時message變量并沒有從undefined變更為一個值。
引起警告的原因是,當message變量在沒有值的情況下被初始化時,它會被設(shè)置為undefined。
傳遞一個像value={undefined}這樣的屬性,就等于根本沒有傳遞value屬性。
一旦用戶在input中開始輸入,value屬性就會被傳遞到input表單,輸入就會從不受控變?yōu)槭芸兀@是不被允許的。
defaultValue
注意,如果你使用一個不受控制的input表單,你應(yīng)該使用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 component changing uncontrolled input報錯解決的詳細內(nèi)容,更多關(guān)于react component uncontrolled報錯的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
詳解React如何實現(xiàn)代碼分割Code Splitting
這篇文章主要為大家介紹了React如何實現(xiàn)代碼分割Code Splitting示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-08-08
React Native全面屏狀態(tài)欄和底部導航欄適配教程詳細講解
最近在寫 React Native 項目,調(diào)試應(yīng)用時發(fā)現(xiàn)頂部狀態(tài)欄和底部全面屏手勢指示條區(qū)域不是透明的,看起來很難受。研究了一下這個問題,現(xiàn)在總結(jié)一下解決方案,這篇文章主要介紹了React Native全面屏狀態(tài)欄和底部導航欄適配教程2023-01-01
React獲取Java后臺文件流并下載Excel文件流程解析
這篇文章主要介紹了React獲取Java后臺文件流下載Excel文件,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-06-06
React Native基礎(chǔ)入門之初步使用Flexbox布局
React中引入了flexbox概念,flexbox是屬于web前端領(lǐng)域CSS的一種布局方案,下面這篇文章主要給大家介紹了關(guān)于React Native基礎(chǔ)入門之初步使用Flexbox布局的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下2018-07-07
使用 React Router Dom 實現(xiàn)路由導航的詳細過程
React Router Dom 是 React 應(yīng)用程序中用于處理路由的常用庫,它提供了一系列組件和 API 來管理應(yīng)用程序的路由,這篇文章主要介紹了使用 React Router Dom 實現(xiàn)路由導航,需要的朋友可以參考下2024-03-03

