<!DOCTYPE html>
<html>
<head>
<meat charset="UTF-8">
<title>高阶函数_函数柯里化</title>
</head>
<body>
<!-- 准备好一个容器 -->
<div id="test"></div>
<!-- 核心库 -->
<script type="text/javascript" src="../js/react.development.js"></script>
<!-- react-dom,操作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>
<!-- 此处一定要写babel -->
<script type="text/babel">
/*
高阶函数:
满足一个就是
1.一函数接收参数是函数就是的
2.一函数接收返回值是函数就是的(下面的event就是函数)
函数柯里化:函数调用继续返回函数,多次处理参数最后统一处理(最后面例子return a+b+c)
*/
//1.创建组件
class Login extends React.Component{
//初始化状态
state ={
username:'',//用户名
password:''//密码
}
//保存表单数据到状态中
saveFormData = (dataType) => {
return (event)=>{
this.setState({[dataType]:event.target.value})
}
//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.saveFormData('uasename')} type="text" name="username"/>
密码: <input onChange={this.saveFormData('password')} type="password" name="password"/>
<button>登录</button>
</form>
)
}
}
//2.渲染组件到页面
ReactDOM.render(<Login/>, document.getElementById("test"));
</script>
</body>
</html>
========================
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>6_函数柯里化</title>
</head>
<body>
<script type="text/javascript">
/* function sum(a,b,c){
return a+b+c
} */
function sum(a){
return(b)=>{
return(c)=>{
return a+b+c
}
}
}
const result=sum(1)(2)(3)
console.log(result)
</script>
</body>
</html>