记录一下实现函数柯里化的过程
这里有一个求和的函数
function sum(a,b,c){return a + b + c;
}
sum(1,2,3) //6
先来了解一下什么是柯里化?
柯里化是一种将使用多个参数的函数转换成一系列使用一个参数的函数的技术。
这种技术通常用于创建一个参数接收器,或者用于提前确定某些参数。
所以,我们现在来创建一下柯里化函数吧,这个函数接收一个需要柯里化的普通函数 fn,然后它返回一个新的函数,直到函数接收的参数的数量达到了fn的参数的数量,那么返回fn的运行结果.
就是实现 curry(sum)(1)(2)(3) 等于6.
上代码
function curry(sum){//debugger//用于接收柯里化函数的每次传入的参数let params = [] //返回一个新的函数,使其再次接收传入的参数return function fun(a){ params.push(a);//判断柯里化函数接收的参数数量是否达到sum的参数总量 if(sum.length > params.length){ return fun;} else {//当柯里化参数达到sum的参数需求量,传入柯里化参数返回sum的运行结果return sum.apply(this, params) } }}
curry(sum)(1)(2)(3) //6