Nuxt Bridge 提供了组合式 API 语法。它专门设计为与 Nuxt 3 对齐。因此,如果您之前一直使用组合式 API,则在启用 Nuxt Bridge 时需要执行一些额外步骤。
@vue/composition-api。nuxt.config 中的模块中)删除 @nuxtjs/composition-api。@vue/composition-api如果您一直只使用 @vue/composition-api 而不是 @nuxtjs/composition-api,那么事情就非常简单。
- import Vue from 'vue'
- import VueCompositionApi from '@vue/composition-api'
-
- Vue.use(VueCompositionApi)
@vue/composition-api 中删除显式导入,并依靠 Nuxt Bridge 为您自动导入它们。@nuxtjs/composition-api 迁移Nuxt Bridge 实现组合式 API 的方式与 @nuxtjs/composition-api 略有不同,并提供了不同的可组合项(旨在与 Nuxt 3 提供的可组合项对齐)。
由于某些可组合项已被移除且尚无替代品,因此这将是一个稍微复杂的过程。
@nuxtjs/composition-api/module您不必立即更新您的导入——Nuxt Bridge 将自动为您当前拥有的大多数导入提供“垫片”,以便您有时间迁移到新的、与 Nuxt 3 兼容的可组合项,但以下情况除外:
withContext 已被移除。请参阅下文。useStatic 已被移除。目前没有替代品。如果您有此用例,请随时提出讨论。reqRef 和 reqSsrRef 现已完全移除。请按照以下关于 ssrRef 的说明进行替换。bridge.capiimport { defineNuxtConfig } from '@nuxt/bridge'
export default defineNuxtConfig({
bridge: {
capi: true,
nitro: false, // If migration to Nitro is complete, set to true
},
})
对于您正在使用的来自 @nuxtjs/composition-api 的其他每个可组合项,请按照以下步骤操作。
$fetchState 和 $fetch 已被移除。
const {
- $fetch,
- $fetchState,
+ fetch,
+ fetchState,
} = useFetch(() => { posts.value = await $fetch('/api/posts') })
defineNuxtMiddleware这是一个类型辅助存根函数,现已移除。
移除 defineNuxtMiddleware 包装器
- import { defineNuxtMiddleware } from '@nuxtjs/composition-api`
- export default defineNuxtMiddleware((ctx) => {})
+ export default (ctx) => {}
对于 TypeScript 支持,您可以使用 @nuxt/types
import type { Middleware } from '@nuxt/types'
export default <Middleware> function (ctx) { }
defineNuxtPlugin这是一个类型辅助存根函数,现已移除。
您也可以继续使用 Nuxt 2 风格的插件,方法是删除函数(如 defineNuxtMiddleware 中所示)。
移除 defineNuxtPlugin 包装器
- import { defineNuxtPlugin } from '@nuxtjs/composition-api'
- export default defineNuxtPlugin((ctx, inject) => {})
+ export default (ctx, inject) => {}
对于 TypeScript 支持,您可以使用 @nuxt/types
import type { Plugin } from '@nuxt/types'
export default <Plugin> function (ctx, inject) {}
useRouter 和 useRouteNuxt Bridge 通过 useRouter 和 useRoute 为这些可组合项提供了直接替代品。
唯一的关键区别是 useRoute 不再返回计算属性。
- import { useRouter, useRoute } from '@nuxtjs/composition-api'
const router = useRouter()
const route = useRoute()
- console.log(route.value.path)
+ console.log(route.path)