Rxjs--创建操作符

创建操作符中除了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 被订阅之前,输入函数是不会执行的.

名称类型属性描述
funcfunction 

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

selectorfunction

可选的

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

schedulerScheduler

可选的

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

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

bindNodeCallback

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

就像是 bindCallback, 但是回调函数必须形如 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, 当观察者( Observer )订阅该 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<T>, scheduler: Scheduler): Observable<T>

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

fromEvent

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

创建一个来自于 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<T>

将任何 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<T>, scheduler: Scheduler): Observable<T>

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

generate

Observable构造函数,和creat一样

interval

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

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

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

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

schedulerScheduler
  • 可选的
  • 默认值: async

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

never

public static never(): Observable

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

13143342_g3j3.png

of

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

这个静态操作符适用于创建简单的 Observable, 该 Observable 只发出给定的参数, 在发送完这些参数后发出完成通知。它可以用来和其他 Observables 组合比如说concat默认情况下, 它使用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 组合, 比如在 mergeMap 中使用

13143353_VQf2.png

timer

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

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

periodnumber
  • 可选的

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

schedulerScheduler
  • 可选的
  • 默认值: async

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

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

13143354_qAyT.png

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值