在 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。
网友回复
python如何调用openai的api实现知识讲解类动画讲解视频的合成?
html如何直接调用openai的api实现海报可视化设计及文本描述生成可编辑海报?
f12前端调试如何找出按钮点击事件触发的那段代码进行调试?
abcjs如何将曲谱播放后导出mid和wav格式音频下载?
python如何将曲子文本生成音乐mp3或wav、mid文件
python中mp3、wav音乐如何转成mid格式?
js在HTML中如何将曲谱生成音乐在线播放并下载本地?
python如何实现在windows上通过键盘来模拟鼠标操作?
python如何给win10电脑增加文件或文件夹右键自定义菜单?
python如何将音乐mp3文件解析获取曲调数据?