2

我有一系列事件:

var eventStream = _([{
  id: 1, foo: 'bar'
}, {
  id: 2, foo: 'baz'
}]);

对于流中的每个事件,我需要加载一个模型实例(我的 DAL 返回 Promise),然后在模型的每个实例上调用一个方法,将原始事件数据中的一些数据作为参数传递。

加载模型实例并不太困难:

eventStream.map(function(data) {
    return getModelPromise(data.id);
}).map(_).merge(); // result is a stream of model instances

但是一旦我有了模型,我就无法弄清楚如何调用模型上的方法并将其传递data.foo给它。基本上,对于我需要做的每个实例:

modelInstance.doStuff(data.foo);

我玩过分叉流,在分叉上拉模型,然后以不同的组合使用zipinvoke,但我没有任何运气。使用 async,我可以通过适当的闭包用户来非常简单地处理这个问题。如何使用 highland.js 使用流来完成此操作?

4

1 回答 1

8

做的最简单的事情可能是包装 getModelPromise 以便它返回一个以您的模型和数据作为属性的对象解析的承诺,而不仅仅是您的模型。

或者,如果您不想使用承诺,您可以在 Highland 中使用:

var modelStream = eventStream.map(function (data) {
    return _(getModelPromise(data.id)).map(function (model) {
        return {data: data, model: model};
    });
}).parallel(10);

// then...
modelStream.map(function (x) {
    x.model.doStuff(x.data.foo);
});

压缩 modelStream 和 eventStream 的观察版本也应该有效,但我通常更喜欢传递包含您需要的所有内容的对象。

于 2014-09-19T13:26:58.833 回答