柯里化箭头函数埋坑记

今天写了个累加的柯里化函数如下:

function add(){
    let that = this;
    let arrs = Array.prototype.slice.call(arguments) 

    function fn(){
        return add.apply(that, arrs.concat(Array.prototype.slice.call(arguments)));
    };
    fn.toString = function (){
        let all = 0;
        for (var i = 0; i < arrs.length; i++) {
            var element = arrs[i];
            all += element;
        }
        return all;
    }
    return fn; 
}

然后运行 console.log(add(1)(2)(3)) 打印 ƒ 6 其中的f可能是谷歌浏览器自己加的。
但是把函数里面的fn修改成如下箭头函数:

var fn = () => {
    return add.apply(that, arrs.concat(Array.prototype.slice.call(arguments)));
};

结果运行结果是 ƒ 4
为什么会是这个样子呢?
这是因为忽略了箭头函数和普通函数的一个很大的区别(当然不是 this 的指向问题),就是箭头函数没有 arguments 对象。
所以每次调用的 arguments 都是最开始时候的参数,也就是上面的1,然后这里总共调用了3次函数,加上刚开始的时候初始化的一次所以共使用了四次第一个参数,也就是 1+1+1+1 也就是 4

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
柯里化(Currying)是一种将接受多个参数的函数转换成一系列接受单个参数的函数的技术。柯里化函数可以用于函数式编程,它的应用非常广泛,下面列举几个常见的应用场景: 1. 参数复用:柯里化函数可以缓存中间结果,用于参数复用。例如,可以将一个接受多个参数的函数转换为一个接受单个参数的函数序列,每次传入一个参数,最后得到结果。这样就可以将一些参数进行复用,提高代码的复用性和可维护性。 2. 预置参数:柯里化函数可以提前将一些参数进行预置。例如,将一个接受多个参数的函数转换为一个接受部分参数的函数,然后将一些参数进行预置,得到一个新的函数。这样就可以将一些参数固定下来,得到一个更加专业化的函数。 3. 延迟执行:柯里化函数可以将函数的执行进行延迟。例如,将一个接受多个参数的函数转换为一个接受部分参数的函数序列,每次传入一个参数,最后得到一个函数。这个函数可以在后续的代码中被调用,实现函数的延迟执行。 4. 函数组合:柯里化函数可以实现函数的组合。例如,将两个函数进行柯里化,然后组合起来,得到一个新的函数。这个新的函数可以将两个函数的功能组合起来,实现更加复杂的功能。 5. 柯里化函数也可以用于实现函数的部分应用,例如Lodash库中的partial和partialRight方法,可以将一个函数的一些参数固定下来,返回一个新的函数,可以在调用时传入剩余的参数。 总之,柯里化函数可以用于函数式编程中的许多场景,能够提高代码的复用性、可维护性、可读性和可拓展性,是一种非常重要的技术。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值