Undefined Navi Data

Navi Data Unavail when Component Renders

2025-01-08

<script setup>
import { useAsyncData, queryContent, fetchContentNavigation } from '#imports'

const { data: navigation } = await useAsyncData('navigation', () =>
  fetchContentNavigation(queryContent('/route/path'))
)
</script>

try-catch

Isolate errors with:

Wrap useAsyncData or useFetch in a try-catch:

try {
  const { data: navigation } = await useAsyncData('navigation', () =>
    fetchContentNavigation(queryContent('/local'))
  )
} catch (error) {
  console.error('Error fetching navigation:', error)
}

pending

<script setup>
const { data: navigation, pending } = await useAsyncData('navigation', () =>
  fetchContentNavigation(queryContent('/local'))
)
</script>

<template>
  <div v-if="pending">Loading navigation...</div>
  <div v-else-if="navigation">
    <NavigationTree :items="navigation" />
  </div>
  <div v-else>Navigation data unavailable</div>
</template>

Computed

<script setup>
const navigationWithExpand = computed(() => {
  return navigation.value ? addExpandProperty(navigation.value) : []
})
</script>

Logic Check

<script setup>
watch(() => navigation.value, () => {
  if (navigation.value) {
    // Your logic here
  }
}, { immediate: true })
</script>

Passing to Child Component

Use v-if:

<template>
  <NavigationTree v-if="navigation" :items="navigation" />
</template>

useLazyAsyncData

Use useLazyAsyncData to render component, then load data:

<script setup>
const { data: navigation, pending } = useLazyAsyncData('navigation', () =>
  fetchContentNavigation(queryContent('/local'))
)
</script>

 

Copyright @ 2024 Anne Brown Â