網站首頁 編程語言 正文
高階函數,
如果一個函數符合下面2個規范中的任何一個,那該函數就是高階函數
1.若A函數,接收的參數是一個函數,那么A就可以稱高階函數
2.若A函數,調用的返回值依然是一個函數,那么A就可以稱為高階函數
常見的高級函數有:Promise,setTimeout(()=>{}),map(()=>{})等等
<!DOCTYPE html>
<html>
<body>
<div id="react"> </div>
<!--準備好一個容器-->
<div id="test"></div>
<!--引入react核心庫,核心庫必須先引入-->
<script type="text/javascript" src="./js/react.development.js"></script>
<!--引入react-dom, 用于支持react操作DOM-->
<script type="text/javascript" src="./js/react-dom.development.js"></script>
<!--引入babel,用于將jsx轉為js-->
<script type="text/javascript" src="./js/babel.min.js"></script>
<!-- 引入prop-types,用于對組件標簽屬性進行限制 -->
<script type="text/javascript" src="./js/prop-types.js"></script>
<div id="react"></div>
<script type="text/babel">
//函數的柯里化:通過函數調用繼續返回函數的方式,實現多次接收參數最后統一處理的函數編碼形式
class Login extends React.Component {
//初始化狀態
state={username:'', password:''}
//自定義賦值事件 ,這塊屬于高階函數,
getData=(data)=>{
console.log(data) //username,password
// const {username,password} =data
return (event)=>{
//console.log("@") //onChange每改變一次,返回值的函數會被調用一次
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函數的返回值作為回調,不加(),會把getData函數本身作為回調*/}
姓名:<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"))
</script>
<style>
.spacing {
margin: 15px;
}
</style>
</body>
</html>
原文鏈接:https://blog.csdn.net/weixin_50379372/article/details/131641964
- 上一篇:沒有了
- 下一篇:沒有了
相關推薦
- 2022-07-21 nginx?配置指令之location使用詳解_nginx
- 2023-05-31 python常用函數random()函數詳解_python
- 2022-11-01 Kotlin?ContentProvider使用方法介紹_Android
- 2022-02-04 Hive在內存不足以存儲所有數據時,會使用外存,而Impala也是如此:錯
- 2022-01-20 淺談關于 && , || , ? : , ?? , ?. 的運算方式以及用法
- 2022-05-18 Python3的正則表達式詳解_python
- 2022-10-03 正則表達式中^和$的含義與實例代碼_正則表達式
- 2022-01-10 cookie localstorage sessionstorage的區別
- 欄目分類
-
- 最近更新
-
- 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同步修改后的遠程分支