Package Exports
- @vueuse/rxjs
Readme
@vueuse/rxjs
This is an add-on of VueUse, enabling a natural way of using RxJS.
Install
npm i @vueuse/rxjs rxjsFunctions
- from— wrappers around RxJS's- from()and- fromEvent()to allow them to accept- refs
- toObserver— sugar function to convert a- refinto an RxJS Observer
- useExtractedObservable— use an RxJS- Observableas extracted from one or more composables
- useObservable— use an RxJS- Observable
- useSubject— bind an RxJS- Subjectto a- refand propagate value changes both ways
- useSubscription— use an RxJS- Subscriptionwithout worrying about unsubscribing from it or creating memory leaks
- watchExtractedObservable— watch the values of an RxJS- Observableas extracted from one or more composables
Example
import { from, fromEvent, useObservable } from '@vueuse/rxjs'
import { forkJoin, of } from 'rxjs'
import { ajax } from 'rxjs/ajax'
import { concatAll, map, mergeMap, pluck, scan, take } from 'rxjs/operators'
import { useTemplateRef } from 'vue'
const BASE_URL = 'https://jsonplaceholder.typicode.com'
const button = useTemplateRef('buttonRef')
const posts = useObservable(
  fromEvent(button, 'click').pipe(
    mergeMap(() => ajax.getJSON(`${BASE_URL}/posts`).pipe(
      concatAll(),
      take(4),
      mergeMap(({ id, userId, title }) => forkJoin({
        id: of(id),
        comments: ajax.getJSON(`${BASE_URL}/posts/${id}/comments`).pipe(
          map(comments => comments.length),
        ),
        username: ajax.getJSON(`${BASE_URL}/users/${userId}`).pipe(
          pluck('username'),
        ),
      }), 2),
      scan((acc, curr) => [...acc, curr], []),
    )),
  ),
)License
MIT License © 2019-PRESENT Anthony Fu