我有一个我想要过滤的数组..听起来很简单我知道.
但是当我做,我仍然得到整个数组…
但是当我做,我仍然得到整个数组…
- constructor(http:Http) {
- this._val = Math.random();
- let s = http.get('https://secure.digitalsignage.com/Digg');
- s.map(s => {
- let news = JSON.parse(s._body);
- return Rx.Observable.fromArray(news);
- }).filter(function(data) {
- console.log('all array ' + data);
- return true;
- }).subscribe(function (v) {
- console.log(v);
- });
- }
所以在console.log(‘所有数组’数据);我得到整个数组而不是一个数组成员的流,为什么?
这里是调试快照:
我知道我不是疯了,因为这样可以预期:
- Rx.Observable.fromArray([1,2,3,4,5]).filter(function (v) {
- if (v < 3)
- return true
- return false;
- }).subscribe(function (v) {
- console.log(v);
- })
是什么赋予了?
tx阅读,
肖恩.
您需要使用
concatMap/
flatMap或任何其他可扩展可观察序列的运算符.
到目前为止,.filter接收到一个可观察数据,而不是数组的各个元素(所有你正在做的是将数组转换为数组的可观察值.第二个例子就像您直接将该过滤器应用于该可观察值).
尝试这个:
- constructor(http:Http) {
- this._val = Math.random();
- let s = http.get('https://secure.digitalsignage.com/Digg');
- s.flatMap(s => {
- let news = JSON.parse(s._body);
- return Rx.Observable.fromArray(news);
- }).filter(function(data) {
- console.log('all array ' + data);
- return true;
- }).subscribe(function (v) {
- console.log(v);
- });
- }
你需要这样做,否则(使用#map)有一个可观察的可观察值(您可以在observable内部返回一个observable),但想要处理新闻中包含的实际值(而不是包含它们的observable).它有点像连接数组并将其添加为元素的区别.
另一种有效的方法是像以前一样使用地图,但是合并发射的可观察值(flatMap / concatMap只是映射和合并一次)
- constructor(http:Http) {
- this._val = Math.random();
- let s = http.get('https://secure.digitalsignage.com/Digg');
- s.map(s => {
- let news = JSON.parse(s._body);
- return Rx.Observable.fromArray(news);
- }).mergeAll() // here you flatten the observable - i.e. you emit just the values contained in incoming observables and lose the observables themselves
- .filter(function(data) {
- console.log('all array ' + data);
- return true;
- }).subscribe(function (v) {
- console.log(v);
- });
- }
如果你不明白任何这个都不用担心,那么people可以比我更好地解释一下:)