我正在努力清理复杂的可观察对象链。我正在遍历从我的秋田商店返回的一系列项目并对每个项目执行操作,然后如果它们已被修改则存储它们。我目前有一个可行的解决方案,但我想知道是否有更清洁或更直接的方法来处理这个链。
我尝试查找一些使用可观察对象循环遍历数组的示例,但没有发现任何复杂的东西或尝试做与我类似的事情。
下面的示例有效,但它似乎不是可观察对象和运算符的最佳实践。
public fetchAdditionalSavedSearchDetails(): Observable<any> {
return this.savedSearchQuery.selectAll().pipe(
// Debounce to prevent from calling to frequently
debounceTime(500),
switchMap((savedSearches) => {
return forkJoin(
// Loop through saved searches and return observable
savedSearches.map((savedSearch) => of(savedSearch).pipe(
// default modified to false
switchMap((savedSearch) => of([savedSearch, false])),
switchMap(([savedSearch, modified]) => {
const search: ISavedSearch = savedSearch as ISavedSearch;
if (search.searchTotalCount === undefined) {
// todo: implement fetching search count
return of([{ ...search, searchTotalCount: 0 }, true]);
}
return of([savedSearch, modified]);
}),
switchMap(([savedSearch, modified]) => {
const search: ISavedSearch = savedSearch as ISavedSearch;
if (search.scheduledExports === undefined) {
return this.scheduledExportService.fetchAllScheduledExportsForSavedSearch(search).pipe(
mergeMap((scheduledExports) => of([{ ...search, scheduledExports }, true]))
);
}
return of([savedSearch, modified]);
})
))
).pipe(tap((response) => {
// Prevent akita store from triggering changes on each update of entity
applyTransaction(() => {
response.forEach((searchResp: Array<ISavedSearch | boolean>) => {
const search: ISavedSearch = searchResp[0] as ISavedSearch;
const modified: boolean = searchResp[1] as boolean;
if (modified) {
this.savedSearchStore.update(search.id, search);
}
});
});
}));
})
);
}