s

函数柯里化

柯里化,是把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数而且返回结果的新函数的技术。

其实本质是函数的一种高阶用法:

 

function curringAdd() {
  let args = [].slice.call(arguments, 0);
  
  function add() {
    args = [...args, [].slice.call(arguments, 0)];
    return add
  }
  
  add.toString = function() {
    return args.reduce((t, a) => t + +a, 0);
  }

  return add;
}

console.log(curringAdd(1)(2)(3)) // 6
console.log(curringAdd(1, 2, 3)(4))  // 10
console.log(curringAdd(1)(2)(3)(4)(5)) // 15
console.log(curringAdd(2, 6)(1)) // 9
console.log(curringAdd(1)) // 1

 

function add() { //这段来自简书
    // 第一次执行时,定义一个数组专门用来存储所有的参数
    var _args = Array.prototype.slice.call(arguments);

    // 在内部声明一个函数,利用闭包的特性保存_args并收集所有的参数值
    var _adder = function() {
        _args.push(...arguments);
        return _adder;
    };

    // 利用toString隐式转换的特性,当最后执行时隐式转换,并计算最终的值返回
    _adder.toString = function () {
        return _args.reduce(function (a, b) {
            return a + b;
        });
    }
    return _adder;
}

add(1)(2)(3)                // 6
add(1, 2, 3)(4)             // 10
add(1)(2)(3)(4)(5)          // 15
add(2, 6)(1)                // 9

 method3:

function   addCur(args) {
 args,reduce((pre,cur)=>{
  return pre + cur ;  
}, 0)
}

function myadd(...args1) {
 const sum1 = addCur(args1);
  const fn = (...args2) => {
  const sum2 = addCur(args2);
  return myadd(sum1+sum2)
} 
fn.tostring = () => {
return sum1;
} return fn }
到这里 就可以 实现 myadd(1)(2)(3) == 6 +. true !!! 这种比较!

  

 

 

posted @ 2021-06-11 14:20  努力不搬砖的iori  阅读(69)  评论(0编辑  收藏  举报