I am writing my Nuxt3 components in the non-composable way and I am not willing to refactor them. I am using useFetch instead of $fetch to avoid double requests in client and server side.. By using .data.value on the refs of useFetch it works without a problem for only one useFetch, until I introduce a second one:

This works:

export default {
  async serverPrefetch() {
    const store = useDataStore()
    await this.fetchData(store);
  },
  mounted() {
    const store = useDataStore()
    this.fetchData(store);
  },
  methods: {
    async fetchData(store) {
      const yesterdayBevData = await useFetch('/api/yesterdayBevs')
      store.setYesterdayBevs(yesterdayBevData.data.value)

      const bevData = await $fetch('/api/getBevSection/1')
      
      store.setBevModels(bevData)
    },
  }
}

but this doesn't work (I replaced one useFetch with $fetch and changed the de-ref code):

export default {
  async serverPrefetch() {
    const store = useDataStore()
    await this.fetchData(store);
  },
  mounted() {
    const store = useDataStore()
    this.fetchData(store);
  },
  methods: {
    async fetchData(store) {
      const yesterdayBevData = await useFetch('/api/yesterdayBevs')
      store.setYesterdayBevs(yesterdayBevData.data.value)

      const bevData = await useFetch('/api/getBevSection/1')
      
      store.setBevModels(bevData.data.value)
    },
  }
}

It seems to be a limitation of composable: https://github.com/nuxt/nuxt/issues/25099

I tried converting the code to something like that:

const nuxtApp = useNuxtApp()
const bevData = await nuxtApp.runWithContext(() => useFetch('/api/getBevSection/'+key))
const yesterdayBevData = await nuxtApp.runWithContext(() => useFetch('/api/yesterdayBevs'))

store.setYesterdayBevs(yesterdayBevData.data.value)
store.setBevModels(bevData.data.value.bev)

Now I don't get the error but I see a request in the client where I shouldn't for the second request

What am I missing? Or is there no way to have multiple fetches and have them accessible in both server and client?

0

There are 0 best solutions below