插件和中间件
了解如何从 Nuxt 2 迁移到 Nuxt Bridge 的新插件和中间件。
新的插件格式
您现在可以迁移到 Nuxt 3 插件 API,其格式与 Nuxt 2 略有不同。
插件现在只接受一个参数 (nuxtApp
)。您可以在文档中了解更多信息。
plugins/hello.ts
export default defineNuxtPlugin(nuxtApp => {
nuxtApp.provide('injected', () => 'my injected function')
// now available on `nuxtApp.$injected`
})
尽管通过
nuxtApp.vueApp
提供了兼容性接口,但您应避免以这种方式注册插件、指令、mixins 或组件,除非您添加自己的逻辑以确保它们不会被多次安装,否则可能会导致内存泄漏。新的中间件格式
您现在可以迁移到 Nuxt 3 中间件 API,其格式与 Nuxt 2 略有不同。
中间件现在只接受两个参数 (to
, from
)。您可以在文档中了解更多信息。
export default defineNuxtRouteMiddleware((to) => {
if (to.path !== '/') {
return navigateTo('/')
}
})
defineNuxtRouteMiddleware
的使用在中间件目录之外不受支持。definePageMeta
您还可以在 Nuxt Bridge 中使用 definePageMeta
。
您可以通过在配置文件中使用 macros.pageMeta
选项来启用它
nuxt.config.ts
import { defineNuxtConfig } from '@nuxt/bridge'
export default defineNuxtConfig({
bridge: {
macros: {
pageMeta: true
}
}
})
但仅适用于
middleware
和 layout
。