Back to Vueuse

useCached

packages/core/useCached/index.md

14.3.0756 B
Original Source

useCached

Cache a ref with a custom comparator.

The comparator signature is (newSourceValue, cachedValue) => boolean. When it returns true, the cache is kept as-is. When it returns false, the cache is updated to the new source value.

Usage

ts
import { useCached } from '@vueuse/core'
import { shallowRef } from 'vue'

interface Data {
  value: number
  extra: number
}

const source = shallowRef<Data>({ value: 42, extra: 0 })
const cached = useCached(source, (newSourceValue, cachedValue) => newSourceValue.value === cachedValue.value)

source.value = {
  value: 42,
  extra: 1,
}

console.log(cached.value) // { value: 42, extra: 0 }

source.value = {
  value: 43,
  extra: 1,
}

console.log(cached.value) // { value: 43, extra: 1 }