useLazyFetch provides a wrapper around useFetch that triggers navigation before the handler is resolved by setting the lazy option to true.


By default, useFetch blocks navigation until its async handler is resolved.

useLazyFetch has the same signature as useFetch.


<div v-if="pending">
Loading ...
<div v-else>
<div v-for="post in posts">
<!-- do something -->
<script setup>
/* Navigation will occur before fetching is complete.
Handle pending and error states directly within your component's template
const { pending, data: posts } = await useLazyFetch('/api/posts')
watch(posts, (newPosts) => {
// Because posts might start out null, you won't have access
// to its contents immediately, but you can watch it.

useLazyFetch is a reserved function name transformed by the compiler, so you should not name your own function useLazyFetch.