網(wǎng)站首頁 編程語言 正文
一、非受控組件
表單中輸入類DOM的值現(xiàn)用現(xiàn)取
<script type="text/babel"> //創(chuàng)建組件 class Login extends React.Component{ handleSubmit = (event)=>{ event.preventDefault() //阻止表單提交 const {username,password} = this alert(`你輸入的用戶名是:${username.value},你輸入的密碼是:${password.value}`) } render(){ return( <form onSubmit={this.handleSubmit}> 用戶名:<input ref={c => this.username = c} type="text" name="username"/> 密碼:<input ref={c => this.password = c} type="password" name="password"/> <button>登錄</button> </form> ) } } //渲染組件 ReactDOM.render(<Login/>,document.getElementById('test')) </script>
二、受控組件
表單中輸入類DOM的值,隨著輸入,能把輸入的值維護到狀態(tài)state
中,需要用的時候再從狀態(tài)中取出來。建議寫受控組件,可以減少ref
的使用
<script type="text/babel"> //創(chuàng)建組件 class Login extends React.Component{ //初始化狀態(tài) state = { username:'', //用戶名 password:'' //密碼 } //保存用戶名到狀態(tài)中 saveUsername = (event)=>{ this.setState({username:event.target.value}) } //保存密碼到狀態(tài)中 savePassword = (event)=>{ this.setState({password:event.target.value}) } //表單提交的回調 handleSubmit = (event)=>{ event.preventDefault() //阻止表單提交 const {username,password} = this.state alert(`你輸入的用戶名是:${username},你輸入的密碼是:${password}`) } render(){ return( <form onSubmit={this.handleSubmit}> 用戶名:<input onChange={this.saveUsername} type="text" name="username"/> 密碼:<input onChange={this.savePassword} type="password" name="password"/> <button>登錄</button> </form> ) } } //渲染組件 ReactDOM.render(<Login/>,document.getElementById('test')) </script>
三、高階函數(shù)(函數(shù)柯里化)實現(xiàn)
1、定義
(1)高階函數(shù)
如果一個函數(shù)符合下面2個規(guī)范中的任何一個,那該函數(shù)就是高階函數(shù)。
1.若A函數(shù),接收的參數(shù)是一個函數(shù),那么A就可以稱之為高階函數(shù)。
2.若A函數(shù),調用的返回值依然是一個函數(shù),那么A就可以稱之為高階函數(shù)。
常見的高階函數(shù)有:Promise、setTimeout、arr.map()等等
(2)函數(shù)的柯里化
通過函數(shù)調用繼續(xù)返回函數(shù)的方式,實現(xiàn)多次接收參數(shù)最后統(tǒng)一處理的函數(shù)編碼形式。
function sum(a){ return(b)=>{ return (c)=>{ return a+b+c } } }
2、實現(xiàn)
<script type="text/babel"> class Login extends React.Component{ state = { username:'', //用戶名 password:'' //密碼 } //保存表單數(shù)據(jù)到狀態(tài)中 saveFormData = (dataType)=>{ return (event)=>{ this.setState({[dataType]:event.target.value}) } } //表單提交的回調 handleSubmit = (event)=>{ event.preventDefault() //阻止表單提交 const {username,password} = this.state alert(`你輸入的用戶名是:${username},你輸入的密碼是:${password}`) } render(){ return( <form onSubmit={this.handleSubmit}> 用戶名:<input onChange={this.saveFormData('username')} type="text" name="username"/> 密碼:<input onChange={this.saveFormData('password')} type="password" name="password"/> <button>登錄</button> </form> ) } } ReactDOM.render(<Login/>,document.getElementById('test')) </script>
onChange
綁定的必須是一個函數(shù),this.saveFormData()
調用saveFormData 函數(shù)的返回值是一個函數(shù)
四、不用函數(shù)柯里化的實現(xiàn)
<script type="text/babel"> class Login extends React.Component{ state = { username:'', //用戶名 password:'' //密碼 } //保存表單數(shù)據(jù)到狀態(tài)中 saveFormData = (dataType,event)=>{ this.setState({[dataType]:event.target.value}) } //表單提交的回調 handleSubmit = (event)=>{ event.preventDefault() //阻止表單提交 const {username,password} = this.state alert(`你輸入的用戶名是:${username},你輸入的密碼是:${password}`) } render(){ return( <form onSubmit={this.handleSubmit}> 用戶名:<input onChange={event => this.saveFormData('username',event) } type="text" name="username"/> 密碼:<input onChange={event => this.saveFormData('password',event) } type="password" name="password"/> <button>登錄</button> </form> ) } } //渲染組件 ReactDOM.render(<Login/>,document.getElementById('test')) </script>
this.saveFormData()
調用saveFormData 函數(shù)返回一個值然后放在一個函數(shù)里面
原文鏈接:https://blog.csdn.net/m0_46613429/article/details/128332218
相關推薦
- 2022-04-09 Webservice 服務請求參數(shù)xml 嵌套問題/CDATA嵌套
- 2022-04-19 C++中拷貝構造函數(shù)的使用_C 語言
- 2022-07-21 Hadoop-HDFS分布式文件系統(tǒng)基礎
- 2022-07-02 C#并行編程之數(shù)據(jù)并行Tasks.Parallel類_C#教程
- 2022-11-29 Android?Jetpack組件DataBinding詳解_Android
- 2022-07-24 .Net行為型設計模式之命令模式(Command)_基礎應用
- 2022-12-27 golang中數(shù)組與切片的區(qū)別詳析_Golang
- 2022-06-21 Windows下安裝Git_其它綜合
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結構-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支