您好,登錄后才能下訂單哦!
這篇文章主要介紹“react component changing uncontrolled input報錯如何解決”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“react component changing uncontrolled input報錯如何解決”文章能幫助大家解決問題。
當input
的值被初始化為undefined
,但后來又變更為一個不同的值時,會產生"A component is changing an uncontrolled input to be controlled"警告。為了解決該問題,將input
的值初始化為空字符串。比如說,value={message || ''}
。
這里有個例子來展示錯誤是如何發生的。
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;
我們使用邏輯與(||)操作符,如果操作符左側的為假值(比如說undefined
),則返回其右側的值。
如果message
變量的值存儲為undefined
,我們將空字符串作為備用值進行返回。
另一種解決方案是,在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
變量在沒有值的情況下被初始化時,它會被設置為undefined
。
傳遞一個像value={undefined}
這樣的屬性,就等于根本沒有傳遞value
屬性。
一旦用戶在input
中開始輸入,value
屬性就會被傳遞到input
表單,輸入就會從不受控變為受控,這是不被允許的。
注意,如果你使用一個不受控制的input
表單,你應該使用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
表單上并沒有設置onChange
或者value
屬性。
你可以使用defaultValue
屬性來為不受控制的input
傳遞初始值。然而,這一步驟不是必要的,如果你不想設置初始值,你可以省略該屬性。
當使用不受控制的input
表單時,我們使用ref
來訪問input
元素。每當用戶點擊例子中的按鈕時,不受控制的input
的值都會被記錄下來。
你不應該為不受控制的input
設置value
屬性,因為這將使input
表單不可變,你將無法在其中輸入。
關于“react component changing uncontrolled input報錯如何解決”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。