コンテンツへスキップ

useObservable

カテゴリ
エクスポートサイズ
212 B
パッケージ
@vueuse/rxjs
最終更新
先週

RxJSのObservableを使用し、refを返し、コンポーネントがアンマウントされたときに自動的にunsubscribeします。 @vueuse/rxjsアドオンで利用できます。

使用方法

ts
import { useObservable } from '@vueuse/rxjs'
import { interval } from 'rxjs'
import { mapTo, scan, startWith } from 'rxjs/operators'
import { ref } from 'vue'

// setup()
const count = useObservable(
  interval(1000).pipe(
    mapTo(1),
    startWith(0),
    scan((total, next) => next + total),
  ),
)
js
import { useObservable } from '@vueuse/rxjs'
import { interval } from 'rxjs'
import { mapTo, scan, startWith } from 'rxjs/operators'
// setup()
const count = useObservable(
  interval(1000).pipe(
    mapTo(1),
    startWith(0),
    scan((total, next) => next + total),
  ),
)

エラーが発生する可能性のあるObservableにカスタムエラー処理を追加する場合は、オプションのonError設定を指定できます。 これがないと、RxJSは提供されたObservableのエラーを「未処理エラー」として扱い、新しいコールスタックでスローされ、window.onerror(または、Nodeにいる場合はprocess.on('error'))に報告されます。

ts
import { useObservable } from '@vueuse/rxjs'
import { interval } from 'rxjs'
import { map } from 'rxjs/operators'
import { ref } from 'vue'

// setup()
const count = useObservable(
  interval(1000).pipe(
    map((n) => {
      if (n === 10)
        throw new Error('oops')

      return n + n
    }),
  ),
  {
    onError: (err) => {
      console.log(err.message) // "oops"
    },
  },
)
js
import { useObservable } from '@vueuse/rxjs'
import { interval } from 'rxjs'
import { map } from 'rxjs/operators'
// setup()
const count = useObservable(
  interval(1000).pipe(
    map((n) => {
      if (n === 10) throw new Error('oops')
      return n + n
    }),
  ),
  {
    onError: (err) => {
      console.log(err.message) // "oops"
    },
  },
)

型宣言

typescript
export interface UseObservableOptions<I> {
  onError?: (err: any) => void
  /**
   * The value that should be set if the observable has not emitted.
   */
  initialValue?: I | undefined
}
export declare function useObservable<H, I = undefined>(
  observable: Observable<H>,
  options?: UseObservableOptions<I | undefined>,
): Readonly<Ref<H | I>>

ソース

ソースドキュメント

コントリビューター

Anthony Fu
Anthony Fu
Curt Grimes
Vincent Schramer
Ben Lesh
Michel Betancourt

変更履歴

v12.0.0-beta.1 2024/11/21
0a9ed - feat!: Vue 2 のサポートを削除、バンドルを最適化、クリーンアップ (#4349)

MITライセンスの下でリリースされています。