关于JS函数柯里化

1.js函数柯里化有什么好处呢?感觉看了一些网站的讲解还是很模糊,比如:

function add(a, b) {

    return a + b;

}


function curryingAdd(a) {

    return function(b) {

        return a + b;

    }

}


add(1, 2); // 3

curryingAdd(1)(2); // 3

都可以实现add功能,那柯里化的好处在哪呢?

2.什么情况下要用柯里化呢?最好能举一些简单易懂的例子。


慕码人2483693
浏览 451回答 1
1回答

SMILET

curry函数可以接受一个函数,我们暂且称之为原始函数,返回的也是一个函数,柯里化函数,这个返回的柯里化函数功能十分强大,他在执行的过程中,不断的返回一个贮存了传入参数的函数,直到触发了原始函数执行的条件。这么说比较概括,那么就举个例子来说明一下:原始函数:    var add = (x, y) => x + y柯里化函数:    var curryAdd = curry(add)这个add需要两个参数,但是我们的curryAdd执行可以传入更少的参数,当传入的参数少于add需要的参数的时候,add函数并不会执行,curryAdd就会将这个参数记下来,并且返回另外一个函数,这个函数可以继续执行传入参数,我们会有一个变量专门记录传入参数的情况,如果传入参数的总数等于add需要参数的总数,我们就激活了原始参数执行,就会返回我们想要的结果。    // 此时只传入了一个参数 根据判断返回的是一个函数    var add2 = curryAdd(2)    // add2 = function(...) {}    // 此时累计传入了两个参数 等于了add需要参数的总和 所以返回的是一个结果    // 相当于执行了add(2)(3)    var result = add2(3)    // result = 5curry的原理实现
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript