如何使用UnderscoreJS进行讨论?

时间:2013-05-13 11:48:59

标签: javascript underscore.js

我有点试验_.bind(...)。我看到如何用bind强制函数上下文,但还没看到如何进行currying。

我尝试的是:

 add = function(number) { this.sum = this.sum + number; }
 add5 = _.bind(add, { sum: 0 }, 5)

但是,调用add5()add5(5)似乎没有效果。

任何线索如何包装参数,以便从一次调用到另一次调用保留上下文?

1 个答案:

答案 0 :(得分:8)

可能你想要部分申请,而不是currying /schönfinkeling。下划线具有_.partial功能:

function add(a, b) { return a+b; }
var add5 = _.partial(add, 5);

您也可以使用_.bind 一些效果。例如:

var add5 = _.bind(add, null /*context is irrelevant*/, 5);
add5(3); // returns 8

然而,您的函数没有返回任何内容,并且您更改的上下文无法访问。但是:

var ctx1 = {sum: 0};
function add(a) { this.sum += a; } // returns nothing!
var addto1 = _.bind(add, ctx1);
addto1(5); // undefined
ctx1; // {sum: 5}

var add5to1 = _.bind(add, ctx1, 5);
add5to1(); // undefined
ctx1; // {sum: 10}

var ctx2 = {sum: 5};
add3to2 = _.bind(add, ctx2, 3);
add3to2(); // undefined
ctx2; // {sum: 8}