柯里化

理解JavaScript的柯里化

函数式编程是一种编程风格,它可以将函数作为参数传递,并返回没有副作用(改变程序状态)的函数。

许多计算机语言都采用了这种编程风格。

由于这种风格具有传递和返回函数的能力,它带来了许多概念:

  • 纯函数
  • 柯里化
  • 高阶函数

什么是柯里化?

柯里化其实是函数式编程的一个过程,在这个过程中我们能把一个带有多个参数的函数转换成一系列的嵌套函数。它返回一个新函数,这个新函数期望传入下一个参数。

它不断地返回新函数(像我们之前讲的,这个新函数期望当前的参数),直到所有的参数都被使用。参数会一直保持 alive (通过闭包),当柯里化函数链中最后一个函数被返回和调用的时候,它们会用于执行。

柯里化是一个把具有较多 arity 的函数转换成具有较少 arity 函数的过程 -- Kristina Brainwave
arity ,指的是函数的参数数量

函数fn接受两个参数(2-arity函数),_fn接受3个参数(3-arity函数)
所以,柯里化把一个多参数函数转换为一系列只带单个参数的函数。

function fn(a,b,c){
  return a*b*c
}

console.log(1,2,3)//6

这个函数接受3个数字,将数字相乘并返回结果。

我们已经将 fn(1,2,3) 函数调用转换为多个 fn(1)(2)(3) 的多个函数调用。

现在创建一个柯里化后的版本,然后看看在一系列的调用中我们如何调用相同的函数(并且得到相同的结果):

function fn(a) {
    return (b) => {
        return (c) => {
            return a * b * c
        }
    }
}
console.log(fn(1)(2)(3)) // 6

我们已经将 fn(1,2,3) 函数调用转换为多个 multiply(1)(2)(3) 的多个函数调用。

一个独立的函数已经被转换为一系列函数。为了得到1, 2 和 3三个数字想成的结果,这些参数一个接一个传递,每个数字都预先传递给下一个函数以便在内部调用。

我们可以拆分 fn(1)(2)(3) 以便更好的理解它:

const f1 = fn(1);
const f2  = f1(2);
const result = f2(3);
image.png

本文摘自掘金《理解JavaScript的柯里化》

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 原文链接 Haskell和scala都支持函数的柯里化,JavaScript函数的柯里化还与JavaScript的...
    dreamapple阅读 2,546评论 0 24
  • 柯里化是函数的一个高级应用,想要理解它并不简单。因此我一直在思考应该如何更加表达才能让大家理解起来更加容易。 通过...
    这波能反杀阅读 69,110评论 117 318
  • 函数柯里化(currying) 我们假设在查看本文档前,您已经有了一定的js基础,并对高阶函数,闭包,call&&...
    技术体验师_萦回阅读 446评论 1 5
  • 【程小平】【日期:2018.04.23】第60天 【一个目标】我三个月短期的目标是:我祈愿所有孩子有激情有梦想,积...
    lindacheng2017阅读 177评论 0 0
  • 是因为八月的到来?是因为那一片蓝?还是因为那一朵流动的云?我竟然沉浸在这对秋日的喜欢里难以自拔。农历八月就是这么一...
    林雅阅读 374评论 2 4