淺析React中的受控組件和非受控組件
非受控組件
表單數(shù)據(jù)由DOM本身處理。即不受setState()的控制,與傳統(tǒng)的HTML表單輸入相似,input輸入值即顯示最新值(使用 ref從DOM獲取表單值)
1.非受控組件
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<!--準(zhǔn)備好一個(gè)容器-->
<div id="test"></div>
<!--引入react核心庫(kù)-->
<script src="../js/react.development.js"></script>
<!--引入react-dom,用于支持react操作dom-->
<script src="../js/react-dom.development.js"></script>
<!--引入babel,用于將jsx轉(zhuǎn)為js-->
<script src="../js/babel.min.js"></script>
<!--引入prop-types,用于對(duì)組件標(biāo)簽屬性進(jìn)行限制-->
<script src="../js/prop-types.js"></script>
<script type="text/babel">
class Login extends React.Component {
myRef1 = React.createRef();
myRef2 = React.createRef();
handleSubmit = (event) => {
event.preventDefault() // 阻止表單提交
const username = this.myRef1.current
const password = this.myRef2.current
alert(`您輸入的用戶名是:${username.value},您輸入的密碼是:${password.value}`)
}
render() {
return (
<form onSubmit={this.handleSubmit}>
用戶名:<input ref={this.myRef1} type="text"/>
密碼:<input ref={this.myRef2} type="text"/>
<button>登錄</button>
</form>
)
}
}
ReactDOM.render(<Login/>,document.getElementById('test'))
</script>
</body>
</html>
受控組件
在HTML中,標(biāo)簽<input>、<textarea>、<select>的值的改變通常是根據(jù)用戶輸入進(jìn)行更新。在React中,可變狀態(tài)通常保存在組件的狀態(tài)屬性中,并且只能使用 setState() 更新,而呈現(xiàn)表單的React組件也控制著在后續(xù)用戶輸入時(shí)該表單中發(fā)生的情況,以這種由React控制的輸入表單元素而改變其值的方式,稱為:“受控組件”。
2.受控組件 (受到控制)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<!--準(zhǔn)備好一個(gè)容器-->
<div id="test"></div>
<!--引入react核心庫(kù)-->
<script src="../js/react.development.js"></script>
<!--引入react-dom,用于支持react操作dom-->
<script src="../js/react-dom.development.js"></script>
<!--引入babel,用于將jsx轉(zhuǎn)為js-->
<script src="../js/babel.min.js"></script>
<!--引入prop-types,用于對(duì)組件標(biāo)簽屬性進(jìn)行限制-->
<script src="../js/prop-types.js"></script>
<script type="text/babel">
class Login extends React.Component {
// 初始化狀態(tài)
state = {
username: '',
password: ''
}
// 保存用戶名到狀態(tài)中
saveUsername = (e) => {
this.setState({username: e.target.value})
}
// 保存密碼到狀態(tài)中
savePassword = (e) => {
this.setState({password: e.target.value})
}
handleSubmit = (e) => {
e.preventDefault() // 阻止表單提交
const {username,password} = this.state
alert(`您輸入的用戶名是:${username},您輸入的密碼是:${password}`)
}
render() {
// onChange是一有變化就改變
return (
<form onSubmit={this.handleSubmit}>
用戶名:<input onChange={this.saveUsername} type="text"/>
密碼:<input onChange={this.savePassword} type="text"/>
<button>登錄</button>
</form>
)
}
}
ReactDOM.render(<Login/>,document.getElementById('test'))
</script>
</body>
</html>

注意
一般情況,受控組件用的多,因?yàn)樵诜鞘芸亟M件中會(huì)多次使用ref,而官方文檔上有些“請(qǐng)勿過(guò)度使用ref”,使用次數(shù)多了會(huì)存在效率上的問(wèn)題。
結(jié)論
受控和非受控元素都有其優(yōu)點(diǎn),根據(jù)具體情況選擇。如果表單在UI反饋方面非常簡(jiǎn)單,則對(duì)ref進(jìn)行控制是完全正確的,即使用非受控組件。
| 特征 | 非受控制 | 受控 |
| 一次性檢索(例如表單提交) | yes | yes |
| 及時(shí)驗(yàn)證 | no | yes |
| 有條件的禁用提交按鈕 | no | yes |
| 執(zhí)行輸入格式 | no | yes |
| 一個(gè)數(shù)據(jù)的幾個(gè)輸入 | no | yes |
| 動(dòng)態(tài)輸入 | no | yes |
以上就是淺析React中的受控組件和非受控組件的詳細(xì)內(nèi)容,更多關(guān)于react受控組件和非受控組件的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
解決React報(bào)錯(cuò)Cannot assign to 'current'
這篇文章主要為大家介紹了React報(bào)錯(cuò)Cannot assign to 'current' because it is a read-only property的解決方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
Native?Memory?Tracking追蹤區(qū)域示例分析
這篇文章主要為大家介紹了Native?Memory?Tracking追蹤區(qū)域示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11
一文詳解React中如何實(shí)現(xiàn)組件懶加載
懶加載是一種優(yōu)化技術(shù),旨在延遲加載不必要的資源,直到它們真正需要時(shí)再進(jìn)行加載,那么React的懶加載是如何實(shí)現(xiàn)的呢,下面小編就來(lái)和大家詳細(xì)講講吧2025-03-03
教你應(yīng)用?SOLID?原則整理?React?代碼之單一原則
這篇文章主要介紹了如何應(yīng)用?SOLID?原則整理?React?代碼之單一原則,今天,我們將從一個(gè)糟糕的代碼示例開(kāi)始,應(yīng)用 SOLID 的第一個(gè)原則,看看它如何幫助我們編寫小巧、漂亮、干凈的并明確責(zé)任的 React 組件,需要的朋友可以參考下2022-07-07
react?express實(shí)現(xiàn)webssh?demo解析
這篇文章主要為大家介紹了詳解react?express實(shí)現(xiàn)webssh?demo解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04
react-router-dom v6版本跳轉(zhuǎn)路徑的實(shí)現(xiàn)方法
這篇文章主要介紹了react-router-dom v6版本跳轉(zhuǎn)路徑的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
react-redux多個(gè)組件數(shù)據(jù)共享的方法
這篇文章主要介紹了react-redux多個(gè)組件數(shù)據(jù)共享的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-08-08
React+Spring實(shí)現(xiàn)跨域問(wèn)題的完美解決方法
這篇文章主要介紹了React+Spring實(shí)現(xiàn)跨域問(wèn)題的完美解決方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-08-08

