博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Rxjs--创建操作符
阅读量:6067 次
发布时间:2019-06-20

本文共 4452 字,大约阅读时间需要 14 分钟。

hot3.png

创建操作符中除了repeat都是静态方法直接从Rx.Observable上使用

取代回调函数(bindCallback、fromPromise)、直接创建(creat、Observable构造函数、from、of、fromEvent)、

惰性创建(defer)、范围连续整数值(range)、连续整数(interval、timer)、重复(repeat)、

用于组合(never、empty、throw)

bindCallback

public static bindCallback(func: function, selector: function, scheduler: Scheduler): function(...params: *): Observable

给它一个签名为f(x, callback)的函数 f ,返回一个函数 g , 调用 'g(x)' 的时候会返回一个 Observable.

很重要的一点是,输出函数返回的 Observable 被订阅之前,输入函数是不会执行的.

名称 类型 属性 描述
func  

最后一个参数是回调的函数。

selector

可选的

选择器,从回调函数中获取参数并将这些映射为一个 Observable 发出的值。

scheduler

可选的

调度器,调度回调函数。默认是同步的

selector 函数接受和回调一样的参数,返回 Observable 发出的值。在默认情况下,传递给回调的多个参数将在流中显示为数组。选择器函数直接用参数调用,就像回调一样.

bindNodeCallback

public static bindNodeCallback(func: function, selector: function, scheduler: Scheduler): *

就像是 , 但是回调函数必须形如 callback(error, result).

从文件系统中读取文件并且从 Observable 中获取数据。import * as fs from 'fs';var readFileAsObservable = Rx.Observable.bindNodeCallback(fs.readFile);var result = readFileAsObservable('./roadNames.txt', 'utf8');result.subscribe(x => console.log(x), e => console.error(e));

create

public static create(onSubscription: function(observer: Observer): TeardownLogic): Observable

创建一个新的 Observable, 当观察者(  )订阅该 Observable 时, 它会执行指定的函数.

defer

public static defer(observableFactory: function(): SubscribableOrPromise): Observable

创建一个 Observable, 当被订阅的时候, 调用 Observable 工厂为每个观察者创建新的 Observable. 延迟创建 Observable, 也就是说, 当且仅当它被订阅的时候才创建

13143340_b4JW.png

empty

public static empty(scheduler: Scheduler): Observable

仅仅发出 complete 通知,其他什么也不做

13143341_u1Sv.png

from

public static from(ish: ObservableInput
, scheduler: Scheduler): Observable

从一个数组、类数组对象、Promise、迭代器对象或者类 Observable 对象创建一个 Observable

fromEvent

public static fromEvent(target: EventTargetLike, eventName: string, options: EventListenerOptions, selector: SelectorMethodSignature
): Observable

创建一个来自于 DOM 事件,或者 Node 的 EventEmitter 事件或者其他事件的 Observable

13143341_zIaB.png

fromEventPattern

public static fromEventPattern(addHandler: function(handler: Function): any, removeHandler: function(handler: Function, signal?: any): void, selector: function(...args: any): T): Observable

将任何 addHandler/removeHandler 的API转化为 Observable

function addClickHandler(handler) {  document.addEventListener('click', handler);}function removeClickHandler(handler) {  document.removeEventListener('click', handler);}

13143342_tnHA.png

fromPromise

public static fromPromise(promise: PromiseLike
, scheduler: Scheduler): Observable

返回一个仅仅发出 Promise resolve 过的值然后完成的 Observable

generate

Observable构造函数,和creat一样

interval

public static interval(period: number, scheduler: Scheduler): Observable

interval 返回一个发出无限自增的序列整数, 你可以选择固定的时间间隔进行发送。 第一次并 没有立马去发送, 而是第一个时间段过后才发出。 默认情况下, 这个操作符使用 async 调度器来 提供时间的概念,但也可以给它传递任意调度器。

名称 类型 属性 描述
period
  • 可选的
  • 默认值: 0

时间间隔,它以毫秒为单位(默认),或者由调度器的内部时钟决定的时间单位。

scheduler
  • 可选的
  • 默认值: async

调度器,用来调度值的发送并提供”时间“的概念。

never

public static never(): Observable

这个静态操作符对于创建既不发出数据也不触发错误和完成通知的 Observable。 可以用来测试或 者和其他 Observables进行组合。 注意,由于不会发送完成通知,这个 Observable 的 subscription 不会被自动地清理。Subscriptions 需要手动清理。

13143342_g3j3.png

of

public static of(values: ...T, scheduler: Scheduler): Observable

这个静态操作符适用于创建简单的 Observable, 该 Observable 只发出给定的参数, 在发送完这些参数后发出完成通知。它可以用来和其他 Observables 组合比如说。 默认情况下, 它使用null调度器,这意味着next通知是同步发出的, 尽管使用不同的调度器可以决定这些通知何时送到。

13143343_xDjD.png

repeat

public repeat(count: number): Observable

返回的 Observable 重复由源 Observable 所发出的项的流,重复 count 次

13143344_UvFj.png

repeatWhen

public repeatWhen(notifier: function(notifications: Observable): Observable): Observable

返回的 Observalbe 是源 Observable 的镜像,除了 complete 。如果源 Observable 调用了 complete,这个方法会发出给 notifier 返回的 Observable 。如果这个 Observale 调用了 complete 或 error,那么这个方法会在子 subscription 上调用 complete 或 error 。

let clicks = Rx.Observable.fromEvent(document, 'click');    let observable = Rx.Observable.of(1, 2);    let subscription = observable.repeatWhen(() => clicks);    subscription.subscribe(res => console.log(res));

13143346_sJFt.png

range

public static range(start: number, count: number, scheduler: Scheduler): Observable

range 操作符顺序发出一个区间范围内的连续整数, 你可以决定区间的开始和长度。 默认情况下, 不使用 调度器仅仅同步的发送通知, 但是也可以可选的使用可选的调度器来控制发送。

13143349_dyq8.png

throw

public static throw(将具体的: any, scheduler: Scheduler): Observable

这个静态操作符对于创建简单的只发出错误通知的 Observable 十分有用。 可以被用来和其他 Observables 组合, 比如在  中使用

13143353_VQf2.png

timer

public static timer(initialDelay: number | Date, period: number, scheduler: Scheduler): Observable
initialDelay  |   

在发出第一个值 0 之前等待的初始延迟时间。

period
  • 可选的

连续数字发送之间的时间周期。

scheduler
  • 可选的
  • 默认值: async

调度器,用来调度值的发送, 提供“时间”的概念。

就像是, 但是可以指定什么时候开始发送

13143354_qAyT.png

转载于:https://my.oschina.net/u/3412211/blog/1606564

你可能感兴趣的文章
重庆构建互联互通新格局 从内陆腹地迈向开放前沿
查看>>
市场监管总局:把校园食品、保健食品作为监管重中之重
查看>>
成都动车段134组动车全面“体检”迎接春运
查看>>
韩国流行家中饮酒 2018年每家每月平均饮酒近6次
查看>>
隐藏黑钻数,修改前十榜单,网易星球给所有相信区块链的人一巴掌
查看>>
通过一个案例理解 JWT
查看>>
独家 | 日本机器学习领军人杉山将:为什么说弱监督学习是未来的热门?
查看>>
【火炉炼AI】机器学习020-使用K-means算法对数据进行聚类分析
查看>>
Python记一次自动脚本历程
查看>>
MVP+Kotlin源码体验
查看>>
makefile--伪目标语法与编程实例
查看>>
看完这个你还不会 插入排序 么
查看>>
Android-压缩大图到容量超小的图片
查看>>
聊聊springboot的HeapDumpWebEndpoint
查看>>
Flux OOM实例
查看>>
Jenkins进阶系列之——01使用email-ext替换Jenkins的默认邮件通知
查看>>
从零搭建自己的SpringBoot后台框架(十一)
查看>>
基本排序算法
查看>>
ES6走走看看—由块级作用域引出的一场变革
查看>>
百度学术改版与 CPU 100% 有关系么?
查看>>