useLazy
A composable for deferring content rendering until first activation, with optional reset on deactivation.
Usage
The useLazy composable tracks whether content has been activated at least once. Content renders only after first activation (unless eager mode is enabled), reducing initial render cost for components like dialogs, menus, and tooltips.
import { shallowRef } from 'vue'
import { useLazy } from '@vuetify/v0'
const isOpen = shallowRef(false)
const { isBooted, hasContent, onAfterLeave } = useLazy(isOpen)
// hasContent becomes true after isOpen is first set to true
// onAfterLeave resets lazy state for transition integrationArchitecture
Reactivity
| Property/Method | Reactive | Notes |
|---|---|---|
isBooted | ShallowRef, readonly | |
hasContent | Computed from isBooted || eager || active | |
active | Accepts MaybeRefOrGetter, watched for changes | |
eager | Accepts MaybeRefOrGetter in options |
Examples
Lazy Content Panel
A collapsible panel that defers rendering until first open (800ms simulated delay), with a loading state while content initializes.
isBooted: false · hasContent: false
Delay
Use the delay option to defer the first mount by a fixed number of milliseconds. This prevents a flash of content for operations that complete very quickly:
const { hasContent } = useLazy(isOpen, { delay: 200 })
// Content only mounts if isOpen stays true for 200msEager Mode
Use the eager option to render content immediately without waiting for activation:
const { hasContent } = useLazy(isOpen, { eager: true })
// hasContent.value is always trueThe eager option accepts a reactive value for dynamic control:
const props = defineProps<{ eager: boolean }>()
const { hasContent } = useLazy(isOpen, {
eager: toRef(() => props.eager),
})Transition Integration
The onAfterLeave callback resets the lazy state after the leave transition completes (unless eager mode is enabled):
<template>
<Transition @after-leave="onAfterLeave">
<div v-if="isOpen">
<template v-if="hasContent">
<!-- Heavy content -->
</template>
</div>
</Transition>
</template>This allows memory to be reclaimed when the content is hidden, while preserving the content during the leave animation.
Functions
useLazy
(active: MaybeRefOrGetter<boolean>, options?: LazyOptions) => LazyContextDeferred content rendering for performance optimization.
Options
eager
MaybeRefOrGetter<boolean> | undefinedWhen true, content renders immediately without waiting for activation.
Default: false
delay
number | undefinedDelay in milliseconds before activation. Prevents flash on quick hover-throughs by requiring the active state to persist for this duration before booting content.
Default: 0
Properties
hasContent
Readonly<Ref<boolean, boolean>>Whether content should be rendered. True when: isBooted OR eager OR active