柯里化函数之Javascript

柯里化函数之Javascript

定义

根据定义来说,柯里化就是将一个接收“多个”参数的函数拆分成一个或者许多个接收“单一”参数的函数。定义看起来是比较抽象的,下面来举个例子:

代码

     
     
1
2
3
4
5
     
     
function concat(str1,str2){
return str1 + str2;
}
concat( "forever", "px") // "foreverpx"

不难理解,上面的代码中定义了一个连接字符串的函数,返回连接两个传入参数的字符串。现在我们再看看另一种定义方式:

     
     
1
2
3
4
5
6
7
8
     
     
function concatCurry(str1){
return function(str2){
return str1 + str2;
}
}
var concatOne = concatCurry( "forever");
concatOne( "px"); //foreverpx

上面的代码中,我们将一开始传入两个参数的函数改装成了一个(或者说是两个)只接收一个参数的函数。

我们来创建一个将接受多个参数的函数柯里化的通用函数:

     
     
1
2
3
4
5
6
7
8
9
     
     
function curry(fn) {
var args = [].slice.call( arguments, 1);
return function() {
return fn.apply( null, args.concat([].slice.call( arguments, 0)));
}
}
var concatOne = curry(concat, "forever");
concatOne( "px"); //foreverpx

柯里化的过程利用了闭包,使得返回的函数也能获得第一次传入的参数。
首先将传入的第二个参数存入args变量中,然后返回一个函数,在返回的函数中,将第一次传入的参数与柯里化之后传入的参数拼接起来成一个数组,然后通过apply方法调用柯里化之前的函数(fn),这样就达到了柯里化的效果。

如果是三个参数的函数想要柯里化,则如下:

     
     
1
2
3
4
5
6
7
8
     
     
function concat(s1,s2,s3){
return s1+s2+s3;
}
var cur1 = curry(concat, "forever");
var cur2 = curry(cur1, "px");
cur2( "-me"); //foreverpx-me

文章作者:foreverpx
文章原文链接:柯里化函数之Javascript

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值