4

有没有更好的方法使用 RxJS 运算符循环从可观察对象返回的数组而不是发出新的单个列表项?

onGetItemData(){
this.dataService.getItemData().subscribe((itemData) =>
{
  this.itemDataJSON = itemData;
  this.itemDataJSON.forEach(function (value) {
    let new_listing = new ListingItem(value.label,value.market,value.name);
    console.log(new_listing);
  });
 });
}

API 返回包含项目的单个数组,因此我无法使用 .map 访问 itemData.name

//-- DataService --// 
getItemData(){
 return this.http.get(this._URL, { headers })
        .pipe(map((res: Listings) => res.items))
}
4

2 回答 2

11

为什么不只是管道 a map()

this.dataService.getItemData()
    .pipe(
        map(itemData => {
            return itemData.map(value => {
                return new ListingItem(value.label, value.market, value.name);
            })
        })
    )
    .subscribe((listingItem) => {
        console.log(listingItem) // gives an array of listingItem
    });

请注意,这.map()是一个 JavaScript 的原生数组函数,您将使用它来转换数据,通过循环遍历数组的每个项目

仅用于单线:

.pipe(
    map(itemData => itemData.map(value => new ListingItem(value.label, value.market, value.name)))
)
于 2018-07-27T03:16:13.153 回答
4

我自己还在学习 Observables,但我认为你可以像我在 StackBlitz 中所做的那样从数组创建一个 Observable:https ://stackblitz.com/edit/angular-tbtvux

简而言之(在 Angular 6 中):

import { from, pipe } from 'rxjs';
...
let observable = from([10, 20, 30])
  .subscribe(v => console.log(v));

所以也许你可以在你的 observable 上通过管道传递 switchMap 运算符,它返回一个数组,如下所示:

import { switchMap } from 'rxjs/operators';
...
yourArrayObservable$.pipe(
  switchMap(val => from(val))
);

...然后你可以像这样使用 map :

import { switchMap, map } from 'rxjs/operators';
...
yourArrayObservable$.pipe(
  switchMap(val => from(val)),
  map(val => val * 42)
);

...至少这似乎在我前面提到的 StackBlitz 中有效。


更新:我认为 flatMap 运算符也可以类似地工作,只有一个运算符:

yourArrayObservable$.pipe(
  flatMap(val => val * 42)
);
于 2018-07-27T01:04:53.310 回答