es6/operator/startWith.js
import { ArrayObservable } from '../observable/ArrayObservable';
import { ScalarObservable } from '../observable/ScalarObservable';
import { EmptyObservable } from '../observable/EmptyObservable';
import { concatStatic } from './concat';
import { isScheduler } from '../util/isScheduler';
/* tslint:enable:max-line-length */
/**
* 返回的 Observable 会先发出作为参数指定的项,然后再发出由源 Observable 所发出的项。
*
* <img src="./img/startWith.png" width="100%">
*
* @param {...T} values - 你希望修改过的 Observable 可以先发出的项。
* @param {Scheduler} [scheduler] - 用于调度 `next` 通知发送的 {@link IScheduler} 。
* @return {Observable} 该 Observable 发出指定的 Iterable 中的项,然后发出由源 Observable 所发出的项。
* @method startWith
* @owner Observable
*/
export function startWith(...array) {
let scheduler = array[array.length - 1];
if (isScheduler(scheduler)) {
array.pop();
}
else {
scheduler = null;
}
const len = array.length;
if (len === 1) {
return concatStatic(new ScalarObservable(array[0], scheduler), this);
}
else if (len > 1) {
return concatStatic(new ArrayObservable(array, scheduler), this);
}
else {
return concatStatic(new EmptyObservable(scheduler), this);
}
}
//# sourceMappingURL=startWith.js.map