概述
本教程操作环境:Windows10系统、react17.0.1版、Dell G3电脑。
什么是react柯里化
函数的柯里化:
通过函数调用继续返回函数的方式,实现多次接受参数最后统一处理的函数编码形式.
扩展:
高阶函数: 若一个函数符合下面两个规范中的一个,该函数就是高阶函数
1.若a函数,接受的参数是一个函数,那么a就可以称为高阶函数
2.若a函数,调用的返回值依旧是一个函数,那么a就可以称之为高阶函数
3.常见的高阶函数有:promise,setTimeout,arr.map等
示例如下;
在form表单中,使用受控组件绑定状态数据,实现点击显示表单数据:
import React, {Component} from 'react';
export default class Form extends Component{
state = {
userName: '',
password: ''
}
submitForm = (event) => {
event.preventDefault() //阻止表单提交
const {userName, password } = this.state;
alert(`${userName}, ${password}`)
}
updateUserName = (event) => {
this.setState({
userName: event.target.value,
})
}
updatePassword = (event) => {
this.setState({
password: event.target.value,
})
}
render() {
return (
<form onSubmit={this.submitForm}>
用户名:<input type="text" name="userName" onChange={this.updateUserName}/>
密码: <input type="password" name="password" onChange={this.updatePassword}/>
<button>登录</button>
</form>
)
}
}
登录后复制
可以看到,这种方法对于表单项多的情况比较繁琐,可以利用函数柯里化来优化:
import React, {Component} from 'react';
export default class Form extends Component{
state = {
userName: '',
password: ''
}
submitForm = (event) => {
event.preventDefault() //阻止表单提交
const {userName, password } = this.state;
alert(`${userName}, ${password}`)
}
updateFormData = (key) => {
return (event) => {
this.setState({
[key]: event.target.value,
})
}
}
render() {
return (
<form onSubmit={this.submitForm}>
用户名:<input type="text" name="userName" onChange={this.updateFormData('userName')}/>
密码: <input type="password" name="password" onChange={this.updateFormData('password')}/>
<button>登录</button>
</form>
)
}
}
登录后复制
this.updateFormData()的返回值是一个回调函数,绑定为onChange的事件,参数为event。这样就可以在初次调用时传类型,触发改变事件时传值了。
不使用函数柯里化的实现
直接在onChange事件绑定为回调,可以实现同时传递类型和值两个参数。
import React, {Component} from 'react';
export default class Form extends Component{
state = {
userName: '',
password: ''
}
submitForm = (event) => {
event.preventDefault() //阻止表单提交
const {userName, password } = this.state;
alert(`${userName}, ${password}`)
}
updateFormData = (key, event) => {
this.setState({
[key]: event.target.value,
})
}
render() {
return (
<form onSubmit={this.submitForm}>
用户名:<input type="text" name="userName" onChange={(event) => this.updateFormData('userName', event)}/>
密码: <input type="password" name="password" onChange={(event) => this.updateFormData('password', event)}/>
<button>登录</button>
</form>
)
}
}
登录后复制
【相关推荐:javascript视频教程、web前端】
以上就是什么是react柯里化的详细内容,更多请关注靠谱客其它相关文章!
最后
以上就是开朗白羊为你收集整理的什么是react柯里化的全部内容,希望文章能够帮你解决什么是react柯里化所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复