js 函数柯里化与连续调用函数实现相加

一、前言

面试的时候遇到一道题目:

实现sum函数,满足以下条件。

sum(1,2,3).valueOf() // 6

sum(1,2,3)(4).valueOf() // 10

sum(1,2,3)(4).valueOf() // 10

sum(1)(2)(3)(4)(5).valueOf() // 15

 咋一看很熟悉,像那个什么返回函数的函数。有那么一瞬间想到是柯里化,但对其只是写过一些add(a,b)的小实例,没有再深入去了解。现在就是后悔,非常后悔。后来面试官和我说是先实现柯里化,再去实现valueOf。

二、柯里化

先说什么是柯里化:

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

举个例子说明:

//这里有个函数 sum
function sum(a,b){
    return a+b;
}

 这个函数正常使用时是要同时传入两个参数a和b。如果这两个参数没办法同时获取,必须分开填入该咋办?要是能先填入一个a,等到b出现了再填入执行该多好呢。这时候柯里化就可以派上用场了,它把多参数的函数变为接受一个参数的函数(这里即接受参数a),并且返回一个新函数,新函数能接受余下的参数(这里就是参数b了),最后返回结果。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值