RxJs Observable的可观察Zip数组

时间:2016-01-28 05:17:21

标签: javascript arrays observable

有一个使用zip来组合固定数量的可观察量的示例,如下所示:

var range = Rx.Observable.range(0, 5);
var source = Observable.zip(
      range,
      range.skip(1),
      range.skip(2),
      function (s1, s2, s3) {
            return s1 + ':' + s2 + ':' + s3;
      }
)

我的问题是,如果我有一个可观察数组(长度可以是任何东西),如何像拉链一样完成同样的事情?

var arr = [observable1, observable2, ..]; //like 100 of them!
var source = Observable.zip(
      //how to put each observable here?
      function (__how to put argument here?_) {
            return /* loop through arguments*/;
      }
)

2 个答案:

答案 0 :(得分:2)

理论上,您可以使用.apply()arguments变量的组合来实现此目的。完全披露:我没有尝试过这段代码。

var arr = [observable1, observable2, ..]; //like 100 of them!
var source = Observable.zip.apply(Observable, 
     arr.concat(function (varargs) { // using "varargs" purely for documentation
         Array.prototype.forEach.apply(arguments, function (observableValue) { 
            /* do something with observableValue */;
         });
     })
);

答案 1 :(得分:0)

自从ES6发布以来,您可以这样简单地将数组作为函数的参数传递:

const arr = [ observable1, observable2, ...]
const source = Observable.zip(...arr)

为我工作:D