網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
需求:
??定義一個(gè)包含表單的組件
?? 輸入用戶(hù)名密碼后, 點(diǎn)擊登錄提示輸入信息
1、包含表單的組件分類(lèi)
1.1、受控組件
??受控組件通過(guò)event.target
獲取對(duì)應(yīng)的DOM節(jié)點(diǎn),event.target.value
獲取節(jié)點(diǎn)的值。 通過(guò)這種方式實(shí)現(xiàn),類(lèi)似于vue的雙向數(shù)據(jù)綁定,input 的值 改變了,對(duì)應(yīng)屬性也改變;屬性值 改變了, input的值也改變。建議使用受控組件,
因?yàn)榉鞘芸亟M件有對(duì)ref的使用,最好不要過(guò)渡使用ref。
//1、創(chuàng)建組件
class Demo extends React.Component {
//初始化狀態(tài)
state = ({
userName: '', pwd: ''
})
saveUserName = (event) => {
// 通過(guò)event.target獲取dom
this.setState({
userName: event.target.value
})
}
savePwd = (event) => {
this.setState({
pwd: event.target.value
})
}
handleSubmit = (event) => {
event.preventDefault();//阻止表單提交
const {userName, pwd} = this.state;
alert(`用戶(hù)名${userName},密碼${pwd}`);
}
render() {
return (
<form onSubmit={this.handleSubmit}>
用戶(hù)名:<input onChange={this.saveUserName} type="text" name="userName" id=""/>
密碼:<input onChange={this.savePwd} type="password" name="password" id=""/>
<button>登錄</button>
</form>
)
}
}
//2、渲染虛擬DOM
ReactDOM.render(<Demo/>, document.getElementById('test'))
??對(duì)上述代碼逐步進(jìn)行優(yōu)化:
方法1:高階函數(shù)—函數(shù)珂里化
??高階函數(shù)
:如果一個(gè)函數(shù)符合下面2個(gè)規(guī)范中的任何一個(gè),那么函數(shù)就是高階函數(shù):
- 若A函數(shù),
接收的參數(shù)是一個(gè)函數(shù)
,那么A就可以稱(chēng)之為高階函數(shù) - 若A函數(shù),
調(diào)用的返回值依然是一個(gè)函數(shù)
,那么A就可以稱(chēng)之為高階函數(shù)
??常見(jiàn)的高階函數(shù)有:Promise、 setTimeout、arr.map()…
?? 函數(shù)的珂里化
:通過(guò)函數(shù)調(diào)用繼續(xù)返回調(diào)用函數(shù)的方式,實(shí)現(xiàn)多次接收參數(shù)最后統(tǒng)一處理的函數(shù)編碼形式。
//1、創(chuàng)建組件
class Demo extends React.Component {
//初始化狀態(tài)
state = ({
userName: '', pwd: ''
})
saveFormDate = (dataType) => {
//高階函數(shù)-函數(shù)珂里化
return (event) => {
console.log(event.target.value);
this.setState({
[dataType]: event.target.value
})
}
}
handleSubmit = (event) => {
event.preventDefault();//阻止表單提交
const {userName, pwd} = this.state;
alert(`用戶(hù)名${userName},密碼${pwd}`);
}
render() {
return (
<form onSubmit={this.handleSubmit}>
用戶(hù)名:<input onChange={this.saveFormDate('userName')} type="text" name="userName" id=""/>
密碼:<input onChange={this.saveFormDate('pwd')} type="password" name="password" id=""/>
<button>登錄</button>
</form>
)
}
}
//2、渲染虛擬DOM
ReactDOM.render(<Demo/>, document.getElementById('test'))
方法2:不用珂里化的方法
saveFormDate = (dataType, event) => {
this.setState({
[dataType]: event.target.value
})
}
render() {
return (
<form onSubmit={this.handleSubmit}>
用戶(hù)名:<input onChange={event => this.saveFormDate('userName', event)} type="text" name="userName"
id=""/>
密碼:<input onChange={event => this.saveFormDate('pwd', event)} type="password" name="password"
id=""/>
<button>登錄</button>
</form>
)
}
方法3:使用自定義屬性data-xxx=‘xxxx’
saveFormDate = (event) => {
let key=event.target.dataset.key
this.setState({
[key]: event.target.value
})
}
render() {
return (
<form onSubmit={this.handleSubmit}>
用戶(hù)名:<input data-key="userName" onChange={this.saveFormDate} type="text" name="userName"
id=""/>
密碼:<input data-key="pwd" onChange={this.saveFormDate} type="password" name="password"
id=""/>
<button>登錄</button>
</form>
)
}
1.2、非受控組件
??通過(guò)ref去獲取表單DOM,然后通過(guò)DOM獲取表單的值,不是通過(guò)react事件去控制。
//創(chuàng)建組件
class Demo extends React.Component {
handleSubmit = (event) => {
event.preventDefault();//阻止表單提交
const {userName, password} = this;
alert(`用戶(hù)名${userName.value},密碼${password.value}`);
}
render() {
return (
<form onSubmit={this.handleSubmit}>
用戶(hù)名:<input ref={c => this.userName = c} type="text" name="userName" id=""/>
密碼:<input ref={c => this.password = c} type="password" name="password" id=""/>
<button>登錄</button>
</form>
)
}
}
ReactDOM.render(<Demo/>, document.getElementById('test'))
原文鏈接:https://blog.csdn.net/fangqi20170515/article/details/126046528
- 上一篇:react組件的生命周期
- 下一篇:react中的事件處理
相關(guān)推薦
- 2022-02-17 ERROR: but there is no HDFS_NAMENODE_USER defined.
- 2022-09-30 Docker容器harbor私有倉(cāng)庫(kù)部署和管理_docker
- 2022-05-04 分享3個(gè)非常實(shí)用的?Python?模塊_python
- 2022-10-13 windows?server設(shè)置FTP域用戶(hù)隔離的方法_FTP服務(wù)器
- 2022-10-11 ArrayList源碼中的MAX_ARRAY_SIZE
- 2023-03-13 React之虛擬DOM的實(shí)現(xiàn)原理_React
- 2022-09-05 Spark Rdd之mapToPair,flatMapToPair
- 2022-07-27 Python?虛擬環(huán)境的價(jià)值和常用命令詳解_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門(mén)
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支