From 50edb86e3a905d8da83155d2f88e182325b7d600 Mon Sep 17 00:00:00 2001 From: Alex Liu Date: Tue, 14 Jan 2025 04:48:20 +0800 Subject: [PATCH] docs: adjust example and additional instructions of `useNuxtData` (#30570) --- docs/3.api/2.composables/use-nuxt-data.md | 72 +++++++++++++++-------- 1 file changed, 49 insertions(+), 23 deletions(-) diff --git a/docs/3.api/2.composables/use-nuxt-data.md b/docs/3.api/2.composables/use-nuxt-data.md index a5d3c99016..a88c010715 100644 --- a/docs/3.api/2.composables/use-nuxt-data.md +++ b/docs/3.api/2.composables/use-nuxt-data.md @@ -9,11 +9,27 @@ links: --- ::note -`useNuxtData` gives you access to the current cached value of [`useAsyncData`](/docs/api/composables/use-async-data) , `useLazyAsyncData`, [`useFetch`](/docs/api/composables/use-fetch) and [`useLazyFetch`](/docs/api/composables/use-lazy-fetch) with explicitly provided key. +`useNuxtData` gives you access to the current cached value of [`useAsyncData`](/docs/api/composables/use-async-data) , [`useLazyAsyncData`](/docs/api/composables/use-lazy-async-data), [`useFetch`](/docs/api/composables/use-fetch) and [`useLazyFetch`](/docs/api/composables/use-lazy-fetch) with explicitly provided key. :: ## Usage +The `useNuxtData` composable is used to access the current cached value of data-fetching composables such as `useAsyncData`, `useLazyAsyncData`, `useFetch`, and `useLazyFetch`. By providing the key used during the data fetch, you can retrieve the cached data and use it as needed. + +This is particularly useful for optimizing performance by reusing already-fetched data or implementing features like Optimistic Updates or cascading data updates. + +To use `useNuxtData`, ensure that the data-fetching composable (`useFetch`, `useAsyncData`, etc.) has been called with an explicitly provided key. + +## Params + +- `key`: The unique key that identifies the cached data. This key should match the one used during the original data fetch. + +## Return Values + +- `data`: A reactive reference to the cached data associated with the provided key. If no cached data exists, the value will be `null`. This `Ref` automatically updates if the cached data changes, allowing seamless reactivity in your components. + +## Example + The example below shows how you can use cached data as a placeholder while the most recent data is being fetched from the server. ```vue [pages/posts.vue] @@ -26,13 +42,15 @@ const { data } = await useFetch('/api/posts', { key: 'posts' }) ```vue [pages/posts/[id\\].vue] @@ -40,7 +58,9 @@ const { data } = useLazyFetch(`/api/posts/${id}`, { ## Optimistic Updates -We can leverage the cache to update the UI after a mutation, while the data is being invalidated in the background. +The example below shows how implementing Optimistic Updates can be achieved using useNuxtData. + +Optimistic Updates is a technique where the user interface is updated immediately, assuming a server operation will succeed. If the operation eventually fails, the UI is rolled back to its previous state. ```vue [pages/todos.vue] ```