網(wǎng)站首頁 編程語言 正文
非授控組件
使用ref來從 DOM 節(jié)點中獲取表單數(shù)據(jù)
表單數(shù)據(jù)將交由 DOM 節(jié)點來處理
非授控組件:先用先取
//非受控組件:先用先取
class Login extends React.Component {
getSubmit=()=>{
//阻止默認事件
event.preventDefault()
alert(`用戶名:${this.ipt.value},密碼:${this.iptT.value}`)
}
render() {
return (
<form action="https://developer.mozilla.org/" onSubmit={this.getSubmit}>
姓名:<input ref={(a)=>{this.ipt=a}} type="text" name="username"/>
密碼:<input ref={(b)=>{this.iptT=b}} type="password" name="password"/>
<button>登錄</button>
</form>
)
}
}
ReactDOM.render(<Login/>,document.getElementById("react"))
授控組件
表單組件的狀態(tài)/數(shù)據(jù)只由state 維護 修改只能通過setState()來更新,
表單數(shù)據(jù)是由 React 組件來管理
//受控組件就是數(shù)據(jù)維護在狀態(tài)state中,當(dāng)需要用的時候直接從狀態(tài)中取出
class Login extends React.Component {
//初始化狀態(tài)
state={username:'', password:''}
//自定義賦值事件
getUserName=(event)=>{
const {username} =this.state
this.setState({username:event.target.value})
}
getPassWord=(event)=>{
const {password} =this.state
this.setState({password:event.target.value})
}
getSubmit=()=>{
//原生阻止默認事件
event.preventDefault()
const {password,username} =this.state
alert(`姓名${username},密碼${password}`)
}
render() {
return (
<form onSubmit={this.getSubmit}>
姓名:<input onChange={this.getUserName} type="text" name="username"/>
<h2>{this.state.username}</h2>
密碼:<input onChange={this.getPassWord} type="password" name="password"/>
<h2>{this.state.password}</h2>
<button>登錄</button>
</form>
)
}
}
ReactDOM.render(<Login/>,document.getElementById("react"))
授控組件用高階函數(shù)與函數(shù)柯里化寫法
//高階函數(shù),如果一個函數(shù)符合下面2個規(guī)范中的任何一個,那該函數(shù)就是高階函數(shù)
// 1.若A函數(shù),接收的參數(shù)是一個函數(shù),那么A就可以稱高階函數(shù)
// 2.若A函數(shù),調(diào)用的返回值依然是一個函數(shù),那么A就可以稱為高階函數(shù)
// 常見的高級函數(shù)有:Promise,setTimeout,map()等等
//函數(shù)的柯里化:通過函數(shù)調(diào)用繼續(xù)返回函數(shù)的方式,實現(xiàn)多次接收參數(shù)最后統(tǒng)一處理的函數(shù)編碼形式
class Login extends React.Component {
//初始化狀態(tài)
state={username:'', password:''}
//自定義賦值事件 ,這塊屬于高階函數(shù),
getData=(data)=>{
// console.log(data) //username,password
// const {username,password} =data
return (event)=>{
//console.log("@") //onChange每改變一次,返回值的函數(shù)會被調(diào)用一次
return this.setState({
[data]:event.target.value
})
}
}
getSubmit=()=>{
//原生阻止默認事件
event.preventDefault()
const {username,password} =this.state
alert(`姓名${username},密碼${password}`)
}
render() {
return (
<form onSubmit={this.getSubmit}>
{/*這塊this.getData("username")加了(),onChange把getData函數(shù)的返回值作為回調(diào),不加(),會把getData函數(shù)本身作為回調(diào)*/}
姓名:<input onChange={this.getData("username")} type="text" name="username"/>
<h2>{this.state.username}</h2>
密碼:<input onChange={this.getData("password")} type="password" name="password"/>
<h2>{this.state.password}</h2>
<button>登錄</button>
</form>
)
}
}
ReactDOM.render(<Login/>,document.getElementById("react"))
授控組件不用函數(shù)柯里化的寫法
class Login extends React.Component {
//初始化狀態(tài)
state={username:'', password:''}
getData=(datatest,e)=>{
this.setState({[datatest]:e})
}
getSubmit=()=>{
//原生阻止默認事件
event.preventDefault()
const {username,password} =this.state
alert(`姓名${username},密碼${password}`)
}
render() {
return (
<form onSubmit={this.getSubmit}>
{/*這塊this.getData("username")加了(),onChange把getData函數(shù)的返回值作為回調(diào),不加(),會把getData函數(shù)本身作為回調(diào)*/}
姓名:<input onChange={(event)=>{return this.getData("username",event.target.value)}} type="text" name="username"/>
<h2>{this.state.username}</h2>
密碼:<input onChange={event=>this.getData("password",event.target.value)} type="password" name="password"/>
<h2>{this.state.password}</h2>
<button>登錄</button>
</form>
)
}
}
ReactDOM.render(<Login/>,document.getElementById("react"))
原文鏈接:https://blog.csdn.net/weixin_50379372/article/details/131194388
- 上一篇:沒有了
- 下一篇:沒有了
相關(guān)推薦
- 2022-08-12 Go本地測試小技巧解耦任務(wù)拆解_Golang
- 2022-12-24 python使用turtle庫寫六角形的思路與代碼_python
- 2022-09-04 Apache?Kafka?分區(qū)重分配的實現(xiàn)原理解析_Linux
- 2022-06-06 MybatisPlus二級緩存體系探究分析_相關(guān)技巧
- 2022-11-29 redis的主從復(fù)制,哨兵和cluster集群
- 2021-12-08 Vmware虛擬機設(shè)置固定IP地址的方法(?圖文教程)_VMware
- 2022-10-15 淺談React?useDebounce?防抖原理_React
- 2022-09-08 Pandas如何將Timestamp轉(zhuǎn)為datetime類型_python
- 欄目分類
-
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學(xué)習(xí)環(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被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支