網站首頁 編程語言 正文
一、非受控組件
表單中輸入類DOM的值現用現取
<script type="text/babel"> //創建組件 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的值,隨著輸入,能把輸入的值維護到狀態state
中,需要用的時候再從狀態中取出來。建議寫受控組件,可以減少ref
的使用
<script type="text/babel"> //創建組件 class Login extends React.Component{ //初始化狀態 state = { username:'', //用戶名 password:'' //密碼 } //保存用戶名到狀態中 saveUsername = (event)=>{ this.setState({username:event.target.value}) } //保存密碼到狀態中 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>
三、高階函數(函數柯里化)實現
1、定義
(1)高階函數
如果一個函數符合下面2個規范中的任何一個,那該函數就是高階函數。
1.若A函數,接收的參數是一個函數,那么A就可以稱之為高階函數。
2.若A函數,調用的返回值依然是一個函數,那么A就可以稱之為高階函數。
常見的高階函數有:Promise、setTimeout、arr.map()等等
(2)函數的柯里化
通過函數調用繼續返回函數的方式,實現多次接收參數最后統一處理的函數編碼形式。
function sum(a){ return(b)=>{ return (c)=>{ return a+b+c } } }
2、實現
<script type="text/babel"> class Login extends React.Component{ state = { username:'', //用戶名 password:'' //密碼 } //保存表單數據到狀態中 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
綁定的必須是一個函數,this.saveFormData()
調用saveFormData 函數的返回值是一個函數
四、不用函數柯里化的實現
<script type="text/babel"> class Login extends React.Component{ state = { username:'', //用戶名 password:'' //密碼 } //保存表單數據到狀態中 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 函數返回一個值然后放在一個函數里面
原文鏈接:https://blog.csdn.net/m0_46613429/article/details/128332218
相關推薦
- 2022-06-12 C語言詳解熱門考點結構體內存對齊_C 語言
- 2022-07-09 Dockerfile文件介紹
- 2022-06-28 C#反射調用dll文件中的方法操作泛型與屬性字段_C#教程
- 2022-06-04 Linux下使用Jenkins自動化構建.NET?Core應用_基礎應用
- 2022-03-30 詳解nginx?location指令_nginx
- 2022-03-31 C語言類的雙向鏈表詳解_C 語言
- 2022-07-26 Python文件系統模塊pathlib庫_python
- 2024-03-10 @Controller、@Service和@Repository注解詳解
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支