首页 > web前端 > js教程 > 正文

mergeMap、switchMap、concatMap、exhaustMap 之间的区别

王林
发布: 2024-09-03 20:14:05
转载
791人浏览过

您好,在作为 angular 开发人员进行面试时,您可能会被问到几个有关 rxj 运算符及其差异的问题。

最常见的问题之一是“mergemap、switchmap、concatmap、exhaustmap 有什么区别?”

让我们深入探讨并用简单的术语解释它们。

我将使用一个简单的例子来解释行为上的差异:

import { interval, take, tap, from } from 'rxjs';
import {
  switchmap,
  mergemap,
  concatmap,
  exhaustmap,
} from 'rxjs/operators';

const mapoperators = [
  mergemap,
  switchmap,
  concatmap,
  exhaustmap
];

const selectedmap = mapoperators[0]; // <- change operator index here

const clicks$ = from(['first click', 'second click', 'third click']).pipe(
  tap(console.log),
);

clicks$
  .pipe(
    selectedmap((click: number) =>
      interval(500).pipe(
        tap((intervalvalue: number) =>
          console.log(
            `${click} value: ${intervalvalue}`
          )
        ),
        take(3)
      )
    )
  )
  .subscribe();

登录后复制

在您可以在 stackblitz 上进行实验的代码示例中,您可以看到 3 次用户点击的模拟

现在,让我们看看每个运算符将返回什么

合并地图

mergeMap、switchMap、concatMap、exhaustMap 之间的区别

first click
second click
third click
first click value: 0
second click value: 0
third click value: 0
first click value: 1
second click value: 1
third click value: 1
first click value: 2
second click value: 2
third click value: 2
登录后复制

mergemap 运算符并行运行排放,这就是你看到的原因

first click value: 0
second click value: 0
third click value: 0
登录后复制

值为 0

美间AI
美间AI

美间AI:让设计更简单

美间AI 45
查看详情 美间AI

切换地图

mergeMap、switchMap、concatMap、exhaustMap 之间的区别

first click
second click
third click
third click value: 0
third click value: 1
third click value: 2

登录后复制

switchmap 运算符将在每次新点击后取消前一个,在我们的例子中,第一次点击将被第二次点击取消,第二次点击将被取消被第三次点击取消,结果我们将看到第三次点击值

third click value: 0
third click value: 1
third click value: 2
登录后复制

concatmap

mergeMap、switchMap、concatMap、exhaustMap 之间的区别

first click
second click
third click
first click value: 0
first click value: 1
first click value: 2
second click value: 0
second click value: 1
second click value: 2
third click value: 0
third click value: 1
third click value: 2
登录后复制

concatmap 运算符将记住所有点击,并以相同的顺序 console.log 它们,在我们的例子中,第一次点击第二次点击第三次点击为你在控制台中看到

first click value: 0
first click value: 1
first click value: 2
second click value: 0
second click value: 1
second click value: 2
third click value: 0
third click value: 1
third click value: 2
登录后复制

排气图

mergeMap、switchMap、concatMap、exhaustMap 之间的区别

first click
second click
third click
first click value: 0
first click value: 1
first click value: 2
登录后复制

exhaustmap 运算符将阻塞流,直到第一次点击完成,在我们的例子中,第二次点击第三次点击将被忽略

First Click Value: 0
First Click Value: 1
First Click Value: 2
登录后复制

现在您了解了这些运算符之间的差异,您可以想象选择错误的后果

以上就是mergeMap、switchMap、concatMap、exhaustMap 之间的区别的详细内容,更多请关注php中文网其它相关文章!

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:dev.to网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号