含义:
偏函数:多元变成n-1元
柯里化:多元变1元
本质就是降元
function multiply(a,b,c){
return a*b*c;
}
multiply();
// 柯里化
function multiply(a){
return (b)=>{
return (c)=>{
return a*b*c;
}
}
}
const test = multiply(1)(2)(3);//6
// console.log('test===',test)
// 通过把一个多参数转化为一系列嵌套的函数,每个函数一次接受一个参数
// dome
let _fn = curry(function(a,b,c,d,e){
console.log('a+b+c+d+e:',a+b+c+d+e);
});
// console.log('_fn:',_fn);
/*偏函数:多元变成n-1元
柯里化:多元变1元
*/
// _fn(1,2,3,4,5);//6 偏函数
// _fn(1)(2)(3,4,5);//15 偏函数
// _fn(1,2)(3,4)(5);//15 偏函数
_fn(1)(2)(3)(4)(5);//15
//柯里化最后返回的都是一个function
//把原始的函数传进来,和 函数的长度传进来
function curry(fn,len=fn.length){
return _curry.call(this,fn,len);
}
//...args:把第一个括号里的参数传进来
function _curry(fn,len,...args){
return function(...params){
console.log('params:',params);
//把之前的参数和这次的参数串成一个数组
let _args = [...args,...params];
console.log('_args:',_args);
//把第一个参数args和第二个参数params加起来,判断后面还有没有参数:
//如果长度所有接受的参数总数之和,就直接执行求和的方法,否则就继续拼接参数
if(_args.length>=len){
return fn.apply(this,_args);
}else{
return _curry.call(this,fn,len,..._args);
}
}
}