1.前端 函数柯里化(currying)
Posted kenneth_zh
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了1.前端 函数柯里化(currying)相关的知识,希望对你有一定的参考价值。
1.什么是函数柯里化?
传递给函数一部分参数用于功能调用,让他返回一个函数去处理剩下的参数。
例1:实现x+y函数
//柯里化前:
let add = (x, y) => x + y;
//柯里化后
let add=x=>(y=>x+y); //第一次调用返回一个函数,继续传入第二个参数调用
//使用:
let add2=add(2); //返回一个函数 y=>y+2
let add200=add(200);
add2(2); //2+2
add200(20) //200+20
例2:对用户年纪的判断,判断用户是否满足变量min
let limit =min=>age=>age>min
//最小年纪为18 ,用户年纪为20
limit(18)(20) //true
//另一种调用方式let limit18=limit(18)
limit18(20)
以上代码造成的问题:
包心菜代码的产生 如: h(g(f(x)))
2.函数组合的概念
通过更优雅的方式实现纯函数的解耦
例:不知道数组长度的情况下,获取数组的最后一个元素(reverse方法)
//写法1:
let reverse=arr=>arr.reverse() //传入一个数组,处理倒叙
let first =arr=>arr[0]; //传入一个数组,取第一个值let handleArr=x=>first(reverse(x))
handleArr([1,2,3,4,5,6]) //6
//写法2:
let compose=(f,g)=>x=>f(g(x))
let reverse = arr=>arr.reverse()
let first = arr=>arr[0]compose(first,reverse)([1,2,3,4,5,6,7])
柯里化让函数变得更灵活,因为我们可以通过一个函数生成一些细粒度更小的函数。这么做的目的是为了在后续函数组合的时候在使用。柯里化可以把多元函数转换成一元函数,目的是可以组合使用函数产生强大的功能。
以上是关于1.前端 函数柯里化(currying)的主要内容,如果未能解决你的问题,请参考以下文章