高阶函数:如果一个函数符合下面2个规范中的任何一个,那该函数就是高阶函数。
1.若A函数,接收的参数是一个函数,那么A就可以称之为高阶函数。
2.若A函数,调用的返回值依然是一个函数,那么A就可以称之为高阶函数。
常见的高阶函数有:Promise、setTimeout、arr.map()等等
函数的柯里化:通过函数调用继续返回函数的方式,实现多次接收参数最后统一处理的函数编码形式。
使用函数柯里化实现:
class Login extends React.Component{
//受控组件,输入框的信息维护到state中
state={
username:'',
password:''
}
handleSubmit=(event)=>{
event.preventDefault()
const {username,password}=this.state
console.log(username,password)
}
//保存信息到状态中
saveFormdata=(dataType)=>{
/*
高阶函数:1.接受参数是一个函数
2.返回值是一个函数
函数柯里化:通过函数调用继续返回函数的形式
*/
//console.log(event.target.value)
// this.setState({username:event.target.value})
// onChange触发的是saveFormdata函数的返回值,而他的返回值 是一个函数,因此
// 下面的return才是onChange的回调函数,event值得是触发事件,event.target是
// 触发事件的元素。
return (event)=>{
this.setState({[dataType]:event.target.value})
}
}
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>
不使用函数柯里化:
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'))