柯里化箭头函数埋坑记

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值