+
95
-

回答

在 RxJS 中,switchMap 和 flatMap(也称为 mergeMap)都是用于处理高阶 Observables 的操作符,它们可以将一个 Observable 转换为另一个 Observable 并将其结果平展为单个 Observable,但它们的行为有显著的区别。

switchMap功能:switchMap 用于切换到一个新的内部 Observable,同时取消前一个内部 Observable。如果源 Observable 发出一个新值,switchMap 会取消前一个内部 Observable 的订阅,并订阅新的内部 Observable。场景:适用于那些你只关心最新的内部 Observable 结果的场景,例如自动补全功能,在用户输入时只处理最后一次输入的结果。

示例

import { of, interval } from 'rxjs';
import { switchMap, take } from 'rxjs/operators';

const source$ = interval(3000); // 每3秒发出一个值
const inner$ = interval(1000).pipe(take(3)); // 每秒发出一个值,发出3个值后完成

source$.pipe(
  switchMap(() => inner$)
).subscribe(value => console.log(value));

在这个例子中,每次 source$ 发出一个值时,都会取消前一个 inner$ Observable 并开始订阅新的 inner$ Observable。最终输出的是每3秒重置一次的每秒的值。

flatMap(mergeMap)功能:flatMap(在 RxJS 中更常用的名字是 mergeMap)用于将每个源 Observable 发出的值映射到一个内部 Observable,然后将所有内部 Observables 发出的值合并成一个 Observable。场景:适用于你希望保留所有内部 Observable 的结果的场景,例如并行处理多个请求,并合并它们的结果。

示例

import { of, interval } from 'rxjs';
import { mergeMap, take } from 'rxjs/operators';

const source$ = interval(3000); // 每3秒发出一个值
const inner$ = interval(1000).pipe(take(3)); // 每秒发出一个值,发出3个值后完成

source$.pipe(
  mergeMap(() => inner$)
).subscribe(value => console.log(value));

在这个例子中,每次 source$ 发出一个值时,都会创建一个新的 inner$ Observable 并订阅它,而不会取消前一个 inner$ Observable。最终输出的是所有并行 inner$ Observables 的值。

总结switchMap:每次源 Observable 发出新值时,取消前一个内部 Observable 的订阅,并订阅新的内部 Observable。适用于只关心最新的内部 Observable 结果的场景。flatMap(mergeMap):每次源 Observable 发出新值时,都会订阅新的内部 Observable,并将所有内部 Observables 的结果合并到一个 Observable。适用于需要保留所有内部 Observable 结果的场景。

选择哪个操作符取决于你具体的应用场景和需求。如果你只关心最新的结果,使用 switchMap;如果你需要处理并保留多个结果,使用 mergeMap。

网友回复

我知道答案,我要回答