3

我正在建立商店行动。我的商店模型如下所示:

{
    entities: {[n:number]: Client},
    ids: number[],
}

我从与给定条件对应的后端获取 id。然后我需要从后端获取那些尚未存储的实体。但我不知道如何将获取的 id 传递给withLatestFrom函数?

const params = {
    conditions,
    fields: ['id']
};
this.apiService.getList(params)
    .pipe(
    map(resp => {
      const ids: number[] = [];
      resp.map((item: Client) => {
        ids.push(+item.id);
      });
      return ids;
    }),
    withLatestFrom(this.checkEntities()), // how to pass ids ?
    tap(resp => {
      patchState({
        entities: resp[1],
        ids: resp[0],
        loading: false
      });
    })
    );

private checkEntities(ids: number[]) {
    const params: ApiWyszukiwarka = {
      conditions: {id: ids},
      fields: 'all'
    };
    return this.apiService.getList(params);
}

或者也许我做错了什么?

4

2 回答 2

3

只是不要使用,而是 withLatestFrom看看。在保持订阅所有作为参数传递的 Observable 的同时,对来自其源 Observable 的每个发射调用其回调,但这不是您所需要的。您只想在获得 id 列表后调用,然后创建一个新的 Observable 并订阅它。concatMapwithLatestFromthis.checkEntities()

所以concatMap你会有这样的东西:

map(resp => {
  ...
  return ids;
}),
concatMap(ids => this.checkEntities(ids))
于 2018-06-28T10:17:15.830 回答
0

我想你可能想使用mergeMap而不是withLatestFrom.

mergeMap允许您映射到可观察对象,然后“展开”该可观察对象。

this.apiService.getList(params)
    .pipe(
      map(resp => resp.map(item => +item.id),
      mergeMap(ids => this.checkEntities(ids)),
      tap(resp => {
        patchState({
          entities: resp[1],
          ids: resp[0],
          loading: false
        });
      })
    );
于 2018-06-28T10:12:53.637 回答