插件和中间件

了解如何从 Nuxt 2 迁移到 Nuxt 3 的插件和中间件。

插件

插件现在有了不同的格式,只接受一个参数(nuxtApp)。

export default (ctx, inject) => {
  inject('injected', () => '我的注入函数')
}
Read more in Docs > Guide > Directory Structure > Plugins.
了解更多关于 nuxtApp 格式的信息。

迁移

  1. 将你的插件迁移为使用 defineNuxtPlugin 辅助函数。
  2. 移除位于 plugins/ 文件夹中的 nuxt.config 插件数组中的任何条目。此目录顶部的所有文件(以及任何子目录中的索引文件)将自动注册。你可以通过文件名而不是设置 modeclientserver 来指明这一点。例如,~/plugins/my-plugin.client.ts 仅在客户端加载。

路由中间件

路由中间件有不同的格式。

export default function ({ store, redirect }) {
  // 如果用户未认证
  if (!store.state.authenticated) {
    return redirect('/login')
  }
}

与 Nuxt 2 类似,放置在 ~/middleware 文件夹中的路由中间件会自动注册。然后,您可以在组件中按名称指定它。但是,这样做是通过 definePageMeta 而不是作为组件选项。

navigateTo 是多个路由辅助函数之一。

Read more in Docs > Guide > Directory Structure > Middleware.

迁移

  1. 将你的路由中间件迁移为使用 defineNuxtRouteMiddleware 辅助函数。
  2. 任何全局中间件(例如在你的 nuxt.config 中)可以放置在 ~/middleware 文件夹中,并带有 .global 扩展名,例如 ~/middleware/auth.global.ts