0

有两个相互依赖的变量(颜色和图片)。取决于以下含义:当变量颜色的值为“蓝色”时,我想过滤所有具有蓝色等颜色的图片。可变图片是带有服务/后端调用的主题:

this.colorSubject.subscribe((color) => {
      subject.switchMap((searchTerm: string) => serviceCall(searchTerm, color) ).subsribe(...)
});

为此,我需要监听颜色变量的变化,然后调用上面的代码行。但这会导致服务的多次调用。

任何想法如何处理这个问题?

4

1 回答 1

0

如果我对您的理解正确,您需要第三个流来表示colorand的连接结果pictures。让我们称之为filteredPictures$。该流应该利用colorpictures使用combineLatest. 现在,如果任何一个流发生变化,filteredPictures$将通知所有订阅者新值。

const {
  Subject,
  from,
  combineLatest
} = rxjs;
const {
  withLatestFrom,
  switchMap
} = rxjs.operators;

const color = new Subject();
const pictures = new Subject();

function service(searchTerm = "house", colorTerm = "green") {
  return Promise.resolve([`${searchTerm}.jpg`, `${colorTerm}.png`]);
}

const color$ = color.asObservable();
const pictures$ = pictures.asObservable();
const filteredPictures$ = combineLatest(
  pictures$,
  color$
).pipe(switchMap(([searchTerm, colorTerm]) => from(service(searchTerm, colorTerm))));

filteredPictures$.subscribe(console.log);

pictures.next("water");
setTimeout(() => {
  color.next("yellow");
  setTimeout(() => {
    pictures.next("helicoptor");
    setTimeout(() => {
      color.next("red");
    }, 1000);
  }, 1000);
}, 1000);
<script src="https://unpkg.com/rxjs/bundles/rxjs.umd.min.js"></script>

于 2018-09-27T18:21:20.417 回答