Nuxt Nation カンファレンスが開催されます。11月12日~13日にご参加ください。

useLazyFetch

この`useFetch`のラッパーは、ナビゲーションを即座にトリガーします。

説明

デフォルトでは、useFetchは、非同期ハンドラが解決されるまでナビゲーションをブロックします。useLazyFetchは、useFetchのラッパーを提供し、lazyオプションをtrueに設定することにより、ハンドラが解決される前にナビゲーションをトリガーします。

useLazyFetchは、useFetchと同じシグネチャを持ちます。
ドキュメント > API > コンポーザブル > Use Fetchで詳細をご覧ください。

pages/index.vue
<script setup lang="ts">
/* Navigation will occur before fetching is complete.
 * Handle 'pending' and 'error' states directly within your component's template
 */
const { status, 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.
})
</script>

<template>
  <div v-if="status === 'pending'">
    Loading ...
  </div>
  <div v-else>
    <div v-for="post in posts">
      <!-- do something -->
    </div>
  </div>
</template>
useLazyFetchはコンパイラによって変換される予約関数名であるため、独自の関数をuseLazyFetchと名付けてはいけません。
ドキュメント > 始める > データフェッチで詳細をご覧ください。