高阶函数_函数柯里化

高阶函数(定义)

如果一个函数符合下面两个规范,就是高阶函数:

  • 如果A函数,接收的参数是一个函数,那么A就是一个高阶函数(比如数组方法arr.map()接收的就是一个处理item的函数了)

  • 如果A函数,调用的返回值依然是一个函数,那么A也称为是高阶函数(常见的高阶函数:Promise、setTimeout、arr.map()等等数组内置的方法)

函数柯里化(定义)

通过函数调用继续返回函数的方式,实现多次接收参数最后统一处理的函数编码形式

(有点像回调地狱的感觉,就是一直then)

一个柯里化的例子:

  1. class Login extends React.Component {
  2. state = {
  3. username: '',
  4. password: ''
  5. }

  6. saveFormData = (dataType) => {
  7. console.log(dataType);
  8. return event => {
  9. this.setState({[dataType] : event.target.value})
  10. }
  11. }
  12. render() {
  13. return (
  14. <form action="http://www.atguigu.com" onSubmit={this.handleSubmit}>
  15. 用户名:<input onChange={this.saveFormData('username')} type="text" name="username"/>
  16. 密码:<input onChange={this.saveFormData('password')} type="password" name="password"/>
  17. <button>登录</button>
  18. </form>
  19. )
  20. }
  21. }
例子疑问一:

为什么通过 this.saveFormData('username') 这样不是会把返回值给onChange函数吗?

回答:如果saveFormData()函数返回的是一个函数的话就可以

解释:

  • 因为this.saveFormData('username'),把‘username’传递作为saveFormData的形参dataType

  • 返回给onChange的函数相当于

  1. onChange={ event => { this.setState({[username] : event.target.value}) } }

所以这个event其实就是这个input的元素对象了

例子疑问二:

为什么用{[dataType] : event.target.value}

解释:

  • 假如我们写的是dataType : event.target.value,其实就相当于是给this.state.dataType赋值了,但是dataType它要表示的是username或者是password,而不是dataType这个变量

比如说 obj = { a: 2} ,可以通过obj.a获取,也可以通过obj[a]获取

而下面其实省略了一点东西,完整的是 this[dataType],因为我们把dataType通过参数传递进来了

它是this的一个属性了,我们访问dataType的时候,其实默认的是通过this.dataType也就是通过

this当前作用域来找到对应的变量的

因为dataType是我们传递过来的形式参数,所以通过this.dataType可以获取到我们的形式参数了

没有柯里化的例子

  1. class Login extends React.Component {
  2. state = {
  3. username: '',
  4. password: ''
  5. }

  6. saveFormData = (dataType, event) => {
  7. this.setState({[dataType] : event.target.value})
  8. }
  9. handleSubmit = (event) => {
  10. event.preventDefault() // 阻止表单提交默认事件
  11. const {username, password} = this.state
  12. alert(`你输入的用户名是:${username}, 你输入的密码是:${password}`)
  13. }
  14. render() {
  15. return (
  16. <form action="http://www.atguigu.com" onSubmit={this.handleSubmit}>
  17. 用户名:<input onChange={event => this.saveFormData('username', event) } type="text" name="username"/>
  18. 密码:<input onChange={event => this.saveFormData('password', event) } type="password" name="password"/>
  19. <button>登录</button>
  20. </form>
  21. )
  22. }
  23. }

React-高阶函数_函数柯里化的更多相关文章

  1. Java函数式编程:二、高阶函数,闭包,函数组合以及柯里化

    承接上文:Java函数式编程:一.函数式接口,lambda表达式和方法引用 这次来聊聊函数式编程中其他的几个比较重要的概念和技术,从而使得我们能更深刻的掌握Java中的函数式编程. 本篇博客主要聊聊以 ...

  2. 浅析 JavaScript 中的 函数 uncurrying 反柯里化

    柯里化 柯里化又称部分求值,其含义是给函数分步传递参数,每次传递参数后部分应用参数,并返回一个更具体的函数接受剩下的参数,这中间可嵌套多层这样的接受部分参数函数,直至返回最后结果. 因此柯里化的过程是 ...

  3. 从 ES6 高阶箭头函数理解函数柯里化

    前言:第一次看到多个连续箭头函数是在一个 react 项目中,然鹅确认了下眼神,并不是对的人,因为看得一脸懵逼.em......于是开始各种搜索,先是知道了多个连续箭头函数就是 es6 的多次柯里化的 ...

  4. JS的闭包、高阶函数、柯里化

    本文原链接:https://cloud.tencent.com/developer/article/1326958 https://cloud.tencent.com/developer/articl ...

  5. Python高阶函数及函数柯里化

    1 Python高阶函数 接收函数为参数,或者把函数作为结果返回的函数为高阶函数. 1.1 自定义sort函数 要求:仿照内建函数sorted,自行实现一个sort函数.内建函数sorted函数是返回 ...

  6. js高阶函数应用—函数柯里化和反柯里化(二)

    第上一篇文章中我们介绍了函数柯里化,顺带提到了偏函数,接下来我们继续话题,进入今天的主题-函数的反柯里化. 在上一篇文章中柯里化函数你可能需要去敲许多代码,理解很多代码逻辑,不过这一节我们讨论的反科里 ...

  7. JavaScript函数柯里化

    函数式 JavaScript是以函数为一等公民的函数式语言.函数在JavaScript中也是一个对象(继承制Function),函数也可以作为参数传递成函数变量.最近几年函数式也因为其无副作用的特性. ...

  8. swift 学习(二)基础知识 (函数,闭包,ARC,柯里化,反射)

    函数 func x(a:Int, b:Int)  {}   func x(a:Int, b:Int) -> Void {}  func x(a:Int, b:Int) ->(Int,Int ...

  9. 浅析 JavaScript 中的 函数 currying 柯里化

    原文:浅析 JavaScript 中的 函数 currying 柯里化 何为Curry化/柯里化? curry化来源与数学家 Haskell Curry的名字 (编程语言 Haskell也是以他的名字 ...

  10. 前端进击的巨人(五):学会函数柯里化(curry)

    柯里化(Curring, 以逻辑学家Haskell Curry命名) 写在开头 柯里化理解的基础来源于我们前几篇文章构建的知识,如果还未能掌握闭包,建议回阅前文. 代码例子会用到 apply/call ...

随机推荐

  1. vue2.0中文文档

    地址1: 链接: https://pan.baidu.com/s/1uEzM990A-W-fl23ref2zww 提取码: rkpt 复制这段内容后打开百度网盘手机App,操作更方便哦 地址2:htt ...

  2. Quartz任务调度(2)CronTrigger定制个性化调度方案

    Cron表达式 1. 时间字段与基本格式 Cron表达式有6或7个空格分割的时间字段组成: 位置 时间域名 允许值 允许的特殊字符 1 秒 0-59 ,-*/ 2 分支 0-59 ,-*?/ 3 小时 ...

  3. 07.SpringMVC之静态资源

    如何你的DispatcherServlet拦截 *.do这样的URL,就不存在访问不到静态资源的问题.如果你的DispatcherServlet拦截"/",拦截了所有的请求,同时对 ...

  4. ConcurrentModificationException异常原因和解决方法

    一.ConcurrentModificationException异常出现的原因 先看下面这段代码: public class Test { public static void main(Strin ...

  5. 统计学习:线性可分支持向量机(SVM)

    模型 超平面 我们称下面形式的集合为超平面 \[\begin{aligned} \{ \bm{x} | \bm{a}^{T} \bm{x} - b = 0 \} \end{aligned} \tag{ ...

  6. SpringCloud升级之路2020.0.x版-24.测试Spring Cloud LoadBalancer

    本系列代码地址:https://github.com/HashZhang/spring-cloud-scaffold/tree/master/spring-cloud-iiford 通过单元测试,我们 ...

  7. Consul 入门-运行

    HashiCorp Consul 是由 HashiCorp 公司开发的,它是一家专注于 DevOps 工具链的公司,旗下的明星级产品包括 Vagrant.Terraform.Vault.Nomad 以 ...

  8. Vivado实战—单周期CPU指令分析

    引言   不知道你是否和我有过同样的感受,<计算机组成原理>这门学科学起来如此的艰难:一节课下来,教室黑板上留下了满满的 "足迹",看上去也挺简单的,不就是 0 和 1 ...

  9. python matplotlib 绘图+显示数值

    参考:https://www.jb51.net/article/152685.htm 用plt.text函数 import numpy as np import matplotlib.mlab as ...

  10. MySQL列举常见的关系型数据库和非关系型都有那些?

    关系型数据库: Oracle.DB2.Microsoft SQL Server.Microsoft Access.MySQL 非关系型数据库: NoSql.Cloudant.MongoDb.redis ...