芝麻web文件管理V1.00
编辑当前文件:/home/freeclou/app.optimyar.com/backend/node_modules/rxjs/src/internal/operators/publish.ts
import { Observable } from '../Observable'; import { Subject } from '../Subject'; import { multicast } from './multicast'; import { ConnectableObservable } from '../observable/ConnectableObservable'; import { MonoTypeOperatorFunction, OperatorFunction, UnaryFunction, ObservableInput, ObservedValueOf } from '../types'; /* tslint:disable:max-line-length */ export function publish
(): UnaryFunction
, ConnectableObservable
>; export function publish
>(selector: (shared: Observable
) => O): OperatorFunction
>; export function publish
(selector: MonoTypeOperatorFunction
): MonoTypeOperatorFunction
; /* tslint:enable:max-line-length */ /** * Returns a ConnectableObservable, which is a variety of Observable that waits until its connect method is called * before it begins emitting items to those Observers that have subscribed to it. * *
Makes a cold Observable hot
* *  * * ## Examples * Make source$ hot by applying publish operator, then merge each inner observable into a single one * and subscribe. * ```ts * import { of, zip, interval, merge } from "rxjs"; * import { map, publish, tap } from "rxjs/operators"; * * const source$ = zip(interval(2000), of(1, 2, 3, 4, 5, 6, 7, 8, 9)).pipe( * map(values => values[1]) * ); * * source$ * .pipe( * publish(multicasted$ => * merge( * multicasted$.pipe(tap(x => console.log('Stream 1:', x))), * multicasted$.pipe(tap(x => console.log('Stream 2:', x))), * multicasted$.pipe(tap(x => console.log('Stream 3:', x))), * ) * ) * ) * .subscribe(); * * // Results every two seconds * // Stream 1: 1 * // Stream 2: 1 * // Stream 3: 1 * // ... * // Stream 1: 9 * // Stream 2: 9 * // Stream 3: 9 * ``` * * @param {Function} [selector] - Optional selector function which can use the multicasted source sequence as many times * as needed, without causing multiple subscriptions to the source sequence. * Subscribers to the given source will receive all notifications of the source from the time of the subscription on. * @return A ConnectableObservable that upon connection causes the source Observable to emit items to its Observers. * @method publish * @owner Observable * * */ export function publish
(selector?: OperatorFunction
): MonoTypeOperatorFunction
| OperatorFunction
{ return selector ? multicast(() => new Subject
(), selector) : multicast(new Subject
()); }