创建操作符中除了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, 也就是说, 当且仅当它被订阅的时候才创建
empty
public static empty(scheduler: Scheduler): Observable
仅仅发出 complete 通知,其他什么也不做
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
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);}
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 |
| 时间间隔,它以毫秒为单位(默认),或者由调度器的内部时钟决定的时间单位。 | |
scheduler |
| 调度器,用来调度值的发送并提供”时间“的概念。 |
never
public static never(): Observable
这个静态操作符对于创建既不发出数据也不触发错误和完成通知的 Observable。 可以用来测试或 者和其他 Observables进行组合。 注意,由于不会发送完成通知,这个 Observable 的 subscription 不会被自动地清理。Subscriptions 需要手动清理。
of
public static of(values: ...T, scheduler: Scheduler): Observable
这个静态操作符适用于创建简单的 Observable, 该 Observable 只发出给定的参数, 在发送完这些参数后发出完成通知。它可以用来和其他 Observables 组合比如说。 默认情况下, 它使用null
调度器,这意味着next
通知是同步发出的, 尽管使用不同的调度器可以决定这些通知何时送到。
repeat
public repeat(count: number): Observable
返回的 Observable 重复由源 Observable 所发出的项的流,重复 count 次
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));
range
public static range(start: number, count: number, scheduler: Scheduler): Observable
range
操作符顺序发出一个区间范围内的连续整数, 你可以决定区间的开始和长度。 默认情况下, 不使用 调度器仅仅同步的发送通知, 但是也可以可选的使用可选的调度器来控制发送。
throw
public static throw(将具体的: any, scheduler: Scheduler): Observable
这个静态操作符对于创建简单的只发出错误通知的 Observable 十分有用。 可以被用来和其他 Observables 组合, 比如在 中使用
timer
public static timer(initialDelay: number | Date, period: number, scheduler: Scheduler): Observable
initialDelay | | | 在发出第一个值 0 之前等待的初始延迟时间。 | |
period |
| 连续数字发送之间的时间周期。 | |
scheduler |
| 调度器,用来调度值的发送, 提供“时间”的概念。 |
就像是, 但是可以指定什么时候开始发送