share.js 1.1 KB

12345678910111213141516171819202122
  1. import { share as higherOrder } from '../operators/share';
  2. /**
  3. * Returns a new Observable that multicasts (shares) the original Observable. As long as there is at least one
  4. * Subscriber this Observable will be subscribed and emitting data. When all subscribers have unsubscribed it will
  5. * unsubscribe from the source Observable. Because the Observable is multicasting it makes the stream `hot`.
  6. *
  7. * This behaves similarly to .publish().refCount(), with a behavior difference when the source observable emits complete.
  8. * .publish().refCount() will not resubscribe to the original source, however .share() will resubscribe to the original source.
  9. * Observable.of("test").publish().refCount() will not re-emit "test" on new subscriptions, Observable.of("test").share() will
  10. * re-emit "test" to new subscriptions.
  11. *
  12. * <img src="./img/share.png" width="100%">
  13. *
  14. * @return {Observable<T>} An Observable that upon connection causes the source Observable to emit items to its Observers.
  15. * @method share
  16. * @owner Observable
  17. */
  18. export function share() {
  19. return higherOrder()(this);
  20. }
  21. ;
  22. //# sourceMappingURL=share.js.map