網(wǎng)站首頁 編程語言 正文
總覽
當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-…
原文鏈接:https://juejin.cn/post/7129148529162846221
相關(guān)推薦
- 2022-06-25 如何利用Pandas刪除某列指定值所在的行_python
- 2022-05-28 Python讀取文件的四種方式的實例詳解_python
- 2022-08-15 SynchronizedList和Vector的區(qū)別
- 2023-10-09 element-ui,tree樹形控件,通過接口返回數(shù)據(jù)判斷是否繼續(xù)拿子節(jié)點
- 2023-02-15 PyQt5+PyQt5Designer的安裝步驟_python
- 2022-07-11 Python利用xlrd?與?xlwt?模塊操作?Excel_python
- 2022-08-11 python?tkinter中的錨點(anchor)問題及處理_python
- 2023-05-26 C語言中#pragma?pack(1)的用法與注意點_C 語言
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學(xué)習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支