RxJS之常见操作符

2023-12-29 12:32
文章标签 常见 操作符 rxjs

本文主要是介绍RxJS之常见操作符,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Rxjs 中文网 https://cn.rx.js.org/
关键:把任何的变化现象成事件流。

常见创建类操作符

1、from:从一个数组、类数组对象、Promise、迭代器对象或者类 Observable 对象创建一个 Observable。
在这里插入图片描述

2、fromEvent:创建一个 Observable,该 Observable 发出来自给定事件对象的指定类型事件。
在这里插入图片描述
3、of:创建一个 Observable,它会依次发出由你提供的参数,最后发出完成通知。
在这里插入图片描述 4 、Interval:创建一个 Observable ,该 Observable 使用指定的 IScheduler ,并以指定时间间隔发出连续的数字。
在这里插入图片描述
5、Timer:创建一个 Observable,该 Observable 在初始延时(initialDelay)之后开始发送并且在每个时间周期( period)后发出自增的数字。
在这里插入图片描述

常见转换类操作符

1、map:将给定的 project 函数应用于源 Observable 发出的每个值,并将结果值作为 Observable 发出。
在这里插入图片描述
2、mapTo:每次源 Observble 发出值时,都在输出 Observable 上发出给定的常量值。
在这里插入图片描述
3、pluck:将每个源值(对象)映射成它指定的嵌套属性。
在这里插入图片描述

常见工具操作符

1、do:为源 Observable 上的每次发送执行副作用,但返回的 Observable 与源 Observable 是相同的。
在这里插入图片描述

常见变换类操作符

1、scan:对源 Observable 使用累加器函数, 返回生成的中间值, 可选的初始值。
在这里插入图片描述

常见数学类操作符

1、reduce:在源 Observalbe 上应用 accumulator (累加器) 函数,然后当源 Observable 完成时,返回 累加的结果,可以提供一个可选的 seed 值。
在这里插入图片描述

常见过滤类操作符

1、filter:通过只发送源 Observable 的中满足指定 predicate 函数的项来进行过滤。
在这里插入图片描述
2、take:只发出源 Observable 最初发出的的N个值 (N = count)。
在这里插入图片描述

3、first/last:只发出由源 Observable 所发出的值中第一个(或第一个满足条件的值)。
在这里插入图片描述
4、skip:返回一个 Observable, 该 Observable 跳过源 Observable 发出的前N个值(N = count)。
在这里插入图片描述
5、debounce:只有在另一个 Observable 决定的一段特定时间经过后并且没有发出另一个源值之后,才从源 Observable 中发出一个值。
在这里插入图片描述
6、debounceTime:只有在特定的一段时间经过后并且没有发出另一个源值,才从源 Observable 中发出一个值。
在这里插入图片描述
7、distinct:返回 Observable,它发出由源 Observable 所发出的所有与之前的项都不相同的项。

6、distinctUntilChanged:返回 Observable,它发出源 Observable 发出的所有与前一项不相同的项。

如果提供了 compare 函数,那么每一项都会调用它来检验是否应该发出这个值。

如果没有提供 compare 函数,默认使用相等检查。

合并类操作符

1、merge:创建一个输出 Observable ,它可以同时发出每个给定的输入 Observable 中的所有值。
在这里插入图片描述
2、concat:创建一个输出 Observable,它在当前 Observable 之后顺序地发出每个给定的输入 Observable 中的所有值。
在这里插入图片描述
3、startWith:返回的 Observable 会先发出作为参数指定的项,然后再发出由源 Observable 所发出的项。
在这里插入图片描述
4、combineLatest:组合多个 Observables 来创建一个 Observable ,该 Observable 的值根据每个输入 Observable 的最新值计算得出的。
在这里插入图片描述
5、withLatestFrom:结合源 Observable 和另外的 Observables 以创建新的 Observable, 该 Observable 的值由每 个 Observable 最新的值计算得出,当且仅当源发出的时候。
在这里插入图片描述
6、zip:将多个 Observable 组合以创建一个 Observable,该 Observable 的值是由所有输入 Observables 的值按顺序计算而来的。

如果最后一个参数是函数, 这个函数被用来计算最终发出的值.否则, 返回一个顺序包含所有输入值的数组.

这篇关于RxJS之常见操作符的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/549443

相关文章

SpringBoot项目整合Netty启动失败的常见错误总结

《SpringBoot项目整合Netty启动失败的常见错误总结》本文总结了SpringBoot集成Netty时常见的8类问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、端口冲突问题1. Tomcat与Netty端口冲突二、主线程被阻塞问题1. Netty启动阻

SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)

《SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)》本文总结了SpringBoot项目整合Kafka启动失败的常见错误,包括Kafka服务器连接问题、序列化配置错误、依赖配置问题、... 目录一、Kafka服务器连接问题1. Kafka服务器无法连接2. 开发环境与生产环境网络不通二、序

在C#中调用Windows防火墙界面的常见方式

《在C#中调用Windows防火墙界面的常见方式》在C#中调用Windows防火墙界面(基础设置或高级安全设置),可以使用进程启动(Process.Start)或Win32API来实现,所以本文给大家... 目录引言1. 直接启动防火墙界面(1) 打开基本防火墙设置(firewall.cpl)(2) 打开高

MySQL中如何求平均值常见实例(AVG函数详解)

《MySQL中如何求平均值常见实例(AVG函数详解)》MySQLavg()是一个聚合函数,用于返回各种记录中表达式的平均值,:本文主要介绍MySQL中用AVG函数如何求平均值的相关资料,文中通过代... 目录前言一、基本语法二、示例讲解1. 计算全表平均分2. 计算某门课程的平均分(例如:Math)三、结合

MyBatis Plus中执行原生SQL语句方法常见方案

《MyBatisPlus中执行原生SQL语句方法常见方案》MyBatisPlus提供了多种执行原生SQL语句的方法,包括使用SqlRunner工具类、@Select注解和XML映射文件,每种方法都有... 目录 如何使用这些方法1. 使用 SqlRunner 工具类2. 使用 @Select 注解3. 使用

Redis高性能Key-Value存储与缓存利器常见解决方案

《Redis高性能Key-Value存储与缓存利器常见解决方案》Redis是高性能内存Key-Value存储系统,支持丰富数据类型与持久化方案(RDB/AOF),本文给大家介绍Redis高性能Key-... 目录Redis:高性能Key-Value存储与缓存利器什么是Redis?为什么选择Redis?Red

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

MySQL ORDER BY 语句常见用法、示例详解

《MySQLORDERBY语句常见用法、示例详解》ORDERBY是结构化查询语言(SQL)中的关键字,隶属于SELECT语句的子句结构,用于对查询结果集按指定列进行排序,本文给大家介绍MySQL... 目录mysql ORDER BY 语句详细说明1.基本语法2.排序方向详解3.多列排序4.常见用法示例5.

MySQL 索引简介及常见的索引类型有哪些

《MySQL索引简介及常见的索引类型有哪些》MySQL索引是加速数据检索的特殊结构,用于存储列值与位置信息,常见的索引类型包括:主键索引、唯一索引、普通索引、复合索引、全文索引和空间索引等,本文介绍... 目录什么是 mysql 的索引?常见的索引类型有哪些?总结性回答详细解释1. MySQL 索引的概念2

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、