当前位置:网站首页>Rxjs map, mergeMap 和 switchMap 的区别和联系
Rxjs map, mergeMap 和 switchMap 的区别和联系
2022-06-28 18:36:00 【汪子熙】
map、mergeMap 和 switchMap 是 RxJS 中的三个主要运算符,在 SAP Spartacus 开发中有着广泛的使用场景。
map
map 是 Observables 中最常见的运算符。 它的作用与数组中的映射相对相似。 map 接收从 Observable 发出的每个值,对其执行操作并返回一个 Observable(因此 Observable 链可以继续)。
把它想象成一个函数,它将采用原始值和投影。 该函数将投影应用于所述值并在转换后返回它们。
让我们举个例子。 假设我们有一个 Observable 数组。 这个数组是一个 Person 的集合。 一个对象代表每个人,每个人都有自己的名字和喜欢的角色。 我们只对获取所有角色的列表感兴趣。
import {
of } from 'rxjs';
import {
map } from 'rxjs/operators';
const observable = of([
{
name: "Parwinder",
character: "Calcifer"
},
{
name: "Laure",
character: "Alchemist"
},
{
name: "Eliu",
character: "X-Men"
},
{
name: "Robert",
character: "Link"
}
]);
observable.pipe(
map(arr => arr.map(person => person.character)) // loops over objects and returns characters
).subscribe(
char => console.log(char) // ["Calcifer", "Alchemist", "X-Men", "Link"]
);
mergeMap
mergeMap 是 Observable map 和 mege 的组合。 在实际项目中,经常需要 map 生成多个 Observable。 例如,现在我有一个角色数组,对于每个角色,我想进行后端调用并获取一些信息。
看下面的例子:
import {
of, from } from 'rxjs';
import {
map } from 'rxjs/operators';
const dummyApi = (character) => {
// fake api call function
return of(`API response for character: ${
character}`).pipe(
delay(1000) // the fake api takes 1 second
);
}
from(["Calcifer", "Alchemist", "X-Men", "Link"]) // characters I need to get information for
.pipe(
map(arr => dummyApi(arr)) // generates 4 new Observables
).subscribe( // subscribing Observable (outer) of 4 Observables (inner)
data => data.subscribe(i => console.log(i)) // subscribing to inner Observables
)
dummyApi 是现实项目中的典型例子:输入某个关键字,返回关键字对应的明细,包裹在一个 Observable 对象里。也就是说,map 投影的输出是一个 Observable,而不是普通对象,因此上面的代码编写了丑陋的嵌套 subscribe 来获取实际值。
使用 mergeMap 后,这个操作符能够自动将 map 返回的 Observable 进行 flatten 操作。使用 map 时丑陋的双重 subscribe 调用消失了。
import {
of, from } from 'rxjs';
import {
mergeMap } from 'rxjs/operators';
const dummyApi = (character) => {
return of(`API response for character: ${
character}`)..pipe(
delay(1000)
);
}
from(["Calcifer", "Alchemist", "X-Men", "Link"])
.pipe(
mergeMap(arr => dummyApi(arr)) // gets 4 Observable as API response and merges them
).subscribe( // we subscribe to one mapped and merged Observable
data => console.log(data)
)
switchMap
switchMap 的功能与 mergeMap 的功能相同,但略有不同。 switchMap 将订阅外部 Observable 中的所有内部 Observable,但不会合并内部 Observable。 它改为切换到最新的 Observable 并将其传递给链。
它仍然提供一个 Observable 作为输出,不是通过合并,而是通过仅从最新的 Observable 发出结果的想法。
对于我们的最后一个示例,如果我们使用 switchMap,我们只会从最后一个 Observable 中获取结果。
import {
of, from } from 'rxjs';
import {
switchMap, delay } from 'rxjs/operators';
const dummyApi = (character) => {
return of(`API response for character: ${
character}`).pipe(
delay(1000)
);
}
from(["Calcifer", "Alchemist", "X-Men", "Link"])
.pipe(
switchMap(arr => dummyApi(arr))
).subscribe(
data => console.log(data) // API response for character: Link
)
有些场景是 switchMap 擅长的,比如所谓的 typehead.
想象这样一个场景:UI 上有一个输入框,我们在其中根据最终用户输入的内容,向其返回搜索结果。
如果用户打算输入 Chase,开始输入 C,然后触发一个 API 调用。 然后客户继续输入 h,我们就必须再次针对 Ch 调用一次后台 API。 此时,我们之前针对 C 的 API 调用已经毫无用处。 我们应该取消之前的 Observable, 并订阅 Ch 对应的 Observable. 更一般性地说,我们需要切换到最新的 Observable.
import {
of, from } from 'rxjs';
import {
switchMap, delay } from 'rxjs/operators';
const dummyApi = (character) => {
return of(`Search result for keyword: ${
character}`).pipe(
delay(1000)
);
}
from(["C", "Ch", "Cha", "Chas", "Chase"]) // mimic key input in text field
.pipe(
switchMap(arr => dummyApi(arr))
).subscribe(
data => console.log(data) // Search result for keyword: Chase
)
边栏推荐
- 19.2 container classification, array and vector container refinement
- 深入解析kubernetes中的选举机制
- 被315点名的流氓下载器,又回来了…
- 原生实现.NET5.0+ 自定义日志
- ONEFLOW source code parsing: automatic inference of operator signature
- 新工作第一天
- Lumiprobe丨Lumizol RNA 提取试剂解决方案
- Yixin Huachen: real estate enterprises want to grasp the opportunity of the times for digital transformation
- 模块化操作
- Concept and code implementation of heap
猜你喜欢

Summary of the use of qobjectcleanuphandler in QT

1 goal, 3 fields, 6 factors and 9 links of digital transformation

Steam education to break the barriers between disciplines

亿信华辰:地产企业数字化转型想要把握时代机遇

Lumiprobe 蛋白质标记研究方案

【Unity3D】发射(RayCast)物理射线(Ray)

Yixin Huachen: real estate enterprises want to grasp the opportunity of the times for digital transformation

牛津大学教授Michael Wooldridge:AI社区近40年如何看待神经网络

MindSpore系列一加载图像分类数据集

19.2 容器分类、array、vector容器精解
随机推荐
About Statistical Distributions
Upload file list (repeated file names are marked with brackets)
C# 41. int与string互转
19.2 容器分类、array、vector容器精解
About Statistical Distributions
[unity3d] emission (raycast) physical ray (Ray)
About Significance Tests
618活动季——百数低代码平台特享折扣来临
百度时间因子添加
SqlTransaction
C# 41. Int to string
Huawei cloud AOM released version 2.0, and three features appeared
1 invalid import format(s) Postman Collection Format v1 is no longer supported and can not be import
正版ST-link/V2 J-LINK JTAG/SWD引脚定义和注意事项
Shell脚本批量修改文件目录权限
牛津大学教授Michael Wooldridge:AI社区近40年如何看待神经网络
微软独家付费功能,也被完美解锁了
leetcode 1423. Maximum Points You Can Obtain from Cards(从牌中能得到的最大点数和)
Konva series tutorial 3: Customizing drawings
memory thrashing