组件选项

了解如何从 Nuxt 2 组件选项迁移到 Nuxt 3 组合式函数。

asyncDatafetch

Nuxt 3 提供了用于从 API 获取数据的新选项。

同构 Fetch

在 Nuxt 2 中,你可能使用 @nuxtjs/axios@nuxt/http 来获取数据 - 或者只是全局的 polyfill fetch

在 Nuxt 3 中,你可以使用全局可用的 fetch 方法,它具有与Fetch API相同的 API,或者使用 $fetch 方法,该方法使用了unjs/ofetch。它有许多优点,包括

  1. 如果它在服务器上运行,它将“智能地”处理直接 API 调用,或者如果它在客户端上运行,则进行客户端调用到你的 API。(它还可以处理调用第三方 API。)
  2. 此外,它还具有便利功能,包括自动解析响应和字符串化数据。

你可以阅读更多关于直接 API 调用获取数据的信息。

可组合项

Nuxt 3 提供了新的组合式函数用于获取数据:useAsyncDatauseFetch。它们都有“懒加载”变体(useLazyAsyncDatauseLazyFetch),它们不会阻塞客户端导航。

在 Nuxt 2 中,你会在组件中使用类似于以下语法的代码获取数据:

export default {
  async asyncData ({ params, $http }) {
    const post = await $http.$get(`https://api.nuxtjs.dev/posts/${params.id}`)
    return { post }
  },
  // or alternatively
  fetch () {
    this.post = await $http.$get(`https://api.nuxtjs.dev/posts/${params.id}`)
  },
}

在你的方法和模板中,你可以像使用组件提供的任何其他数据一样使用 post 变量。

在 Nuxt 3 中,你可以在 setup() 方法或 <script setup> 标签中使用组合式函数执行数据获取。

<script setup lang="ts">
// Define params wherever, through `defineProps()`, `useRoute()`, etc.
const { data: post, refresh } = await useAsyncData('post', () => $fetch(`https://api.nuxtjs.dev/posts/${params.id}`))
// Or instead - useFetch is a convenience wrapper around useAsyncData when you're just performing a simple fetch
const { data: post, refresh } = await useFetch(`https://api.nuxtjs.dev/posts/${params.id}`)
</script>

你现在可以在 Nuxt 3 模板中使用 post,或者调用 refresh 来更新数据。

尽管名称相似,useFetch 并不是 fetch() 钩子的直接替代品。相反,useAsyncData 替代了这两个钩子,并且更具可定制性;它不仅可以从端点获取数据。useFetchuseAsyncData 的便捷包装器,用于简单地从端点获取数据。

迁移

  1. 在你的页面/组件中,用 useAsyncDatauseFetch 替换 asyncData 钩子。
  2. 在你的组件中,用 useAsyncDatauseFetch 替换 fetch 钩子。
文档 > 4 X > 迁移 > 元数据 中阅读更多内容。

key

你现在可以在 definePageMeta 编译器宏中定义一个键。

app/pages/index.vue
- <script>
- export default {
-   key: 'index'
-   // or a method
-   // key: route => route.fullPath
- }
+ <script setup>
+ definePageMeta({
+   key: 'index'
+   // or a method
+   // key: route => route.fullPath
+ })
</script>

layout

文档 > 4 X > 迁移 > 页面和布局 中阅读更多内容。

加载

Nuxt 3 尚不支持此功能。

middleware

文档 > 4 X > 迁移 > 插件和中间件 中阅读更多内容。

scrollToTop

Nuxt 3 尚不支持此功能。如果你想覆盖 vue-router 的默认滚动行为,你可以在 ~/router.options.ts 中进行(详见文档)。与 key 类似,在 definePageMeta 编译器宏中指定它。

app/pages/index.vue
- <script>
- export default {
-   scrollToTop: false
- }
+ <script setup>
+ definePageMeta({
+   scrollToTop: false
+ })
</script>

transition

文档 > 4 X > 入门 > 过渡中阅读更多内容。

validate

Nuxt 3 中的 validate 钩子只接受一个参数,即 route。与 Nuxt 2 中一样,你可以返回一个布尔值。如果返回 false 且找不到其他匹配项,则表示 404 错误。你也可以直接返回一个带有 statusCode/statusMessage 的对象,以立即响应错误(其他匹配项将不会被检查)。

app/pages/users/[id].vue
- <script>
- export default {
-   async validate({ params }) {
-     return /^\d+$/.test(params.id)
-   }
- }
+ <script setup>
+ definePageMeta({
+   validate: async (route) => {
+     const nuxtApp = useNuxtApp()
+     return /^\d+$/.test(route.params.id)
+   }
+ })
  </script>

watchQuery

Nuxt 3 不支持此功能。你可以直接使用 watcher 来触发数据重新获取。

app/pages/users/[id].vue
<script setup lang="ts">
const route = useRoute()
const { data, refresh } = await useFetch('/api/user')
watch(() => route.query, () => refresh())
</script>