在 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。
网友回复
如何修改别人发给我的微信笔记内容?
fbx、obj、glb三维格式模型如何在浏览器中通过three相互转换格式?
python如何实现基于http隧道加密的正向代理服务?
有没有有专门针对 UI 界面截图进行智能标记(Set-of-Mark, SoM) 的开源库和工具?
如何用python实现Set-of-Mark (SoM) 技术?
python如何截取windows指定应用的窗口截图,不用管窗口是不是在最前面?
linux能不能给rm删除命令增加回收站功能,可恢复被删文件?
bfwsoa如何在命令行中执行控制器动作器方法?
RAG(检索增强生成)和 KG(知识图谱)有啥不同?
KVM硬件是啥?


