Nuxt/docs/3.api/1.composables/use-lazy-fetch.md
Sébastien Chopin 3ec108493d
docs: simplify the docs directory (#18506)
* docs: simplify docs to only markdown

* Create nuxt-config.md

* chore: update

* chore: add readme
2023-01-25 10:41:41 +01:00

1.1 KiB

description
This wrapper around useFetch triggers navigation immediately.

useLazyFetch

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

Description

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

useLazyFetch has the same signature as useFetch.

:ReadMore{link="/docs/api/composables/use-fetch"}

Example

<template>
  <div v-if="pending">
    Loading ...
  </div>
  <div v-else>
    <div v-for="post in posts">
      <!-- do something -->
    </div>
  </div>
</template>

<script setup>
/* Navigation will occur before fetching is complete.
  Handle pending and error states directly within your component's template
*/
const { pending, data: posts } = useLazyFetch('/api/posts')
watch(posts, (newPosts) => {
  // Because posts starts out null, you won't have access
  // to its contents immediately, but you can watch it.
})
</script>

:ReadMore{link="/docs/getting-started/data-fetching#uselazyfetch"}