在 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。
网友回复
webgl与webgpu有啥不同?
Zero Trust的Tunnels怎么设置泛域名解析及http服务获取当前访问域名?
Spec Coding(规范驱动编码)和 Vibe Coding(氛围编程)有啥区别?
如何在国内服务器上正常运行未备案的域名网站?
Cloudflared 和WARP Connector有啥不同?
有没有让本地开源大模型越狱的方法或插件啥的?
如何使用Zero Trust的Tunnels技术将局域网电脑web服务可以公网访问呢?
编程领域ai大模型的排名是怎么样的?
如何修改别人发给我的微信笔记内容?
fbx、obj、glb三维格式模型如何在浏览器中通过three相互转换格式?


