react component changing uncontrolled input報(bào)錯(cuò)解決
總覽
當(dāng)input
的值被初始化為undefined
,但后來又變更為一個(gè)不同的值時(shí),會(huì)產(chǎn)生"A component is changing an uncontrolled input to be controlled"警告。為了解決該問題,將input
的值初始化為空字符串。比如說,value={message || ''}
。
這里有個(gè)例子來展示錯(cuò)誤是如何發(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
,因?yàn)槲覀儧]有在useState
鉤子中為其傳遞初始值。
備用值
解決該錯(cuò)誤的一種方式是,如果input
的值為undefined
,那么就提供一個(gè)備用值。
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
變量的值存儲(chǔ)為undefined
,我們將空字符串作為備用值進(jìn)行返回。
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
鉤子中傳遞初始值可以避免警告,因?yàn)榇藭r(shí)message
變量并沒有從undefined
變更為一個(gè)值。
引起警告的原因是,當(dāng)message
變量在沒有值的情況下被初始化時(shí),它會(huì)被設(shè)置為undefined
。
傳遞一個(gè)像value={undefined}
這樣的屬性,就等于根本沒有傳遞value
屬性。
一旦用戶在input
中開始輸入,value
屬性就會(huì)被傳遞到input
表單,輸入就會(huì)從不受控變?yōu)槭芸?,這是不被允許的。
defaultValue
注意,如果你使用一個(gè)不受控制的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è)置初始值,你可以省略該屬性。
當(dāng)使用不受控制的input
表單時(shí),我們使用ref
來訪問input
元素。每當(dāng)用戶點(diǎn)擊例子中的按鈕時(shí),不受控制的input
的值都會(huì)被記錄下來。
你不應(yīng)該為不受控制的input
設(shè)置value
屬性,因?yàn)檫@將使input
表單不可變,你將無法在其中輸入。
原文鏈接:bobbyhadz.com/blog/react-…
以上就是react component changing uncontrolled input報(bào)錯(cuò)解決的詳細(xì)內(nèi)容,更多關(guān)于react component uncontrolled報(bào)錯(cuò)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- Can't?perform?a?React?state?update?on?an?unmounted?component報(bào)錯(cuò)解決
- Objects are not valid as a React child報(bào)錯(cuò)解決
- React Hook 'useEffect' is called in function報(bào)錯(cuò)解決
- React hook 'useState' is called conditionally報(bào)錯(cuò)解決
- React報(bào)錯(cuò)解決之ref返回undefined或null
- React報(bào)錯(cuò)Element type is invalid解決案例
相關(guān)文章
react系列從零開始_簡(jiǎn)單談?wù)剅eact
下面小編就為大家?guī)硪黄猺eact系列從零開始_簡(jiǎn)單談?wù)剅eact。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07React模擬實(shí)現(xiàn)Vue的keepAlive功能
Vue中,keep-alive組件可以緩存組件狀態(tài),在路由切換時(shí)重新掛載,實(shí)現(xiàn)這一功能在React中并不簡(jiǎn)單,但我們可以借助一個(gè)第三方庫——react-activation 來模擬Vue的keep-alive功能,需要的朋友可以參考下2024-10-10React中useState原理的代碼簡(jiǎn)單實(shí)現(xiàn)
要實(shí)現(xiàn)useState的背后原理,則需要深入了解狀態(tài)是如何在函數(shù)組件的渲染周期中保持和更新的,本文將通過一段代碼簡(jiǎn)單闡述useState鉤子函數(shù)的實(shí)現(xiàn)思路,希望對(duì)大家有所幫助2023-12-12