页面

源文件
Nuxt Kit 提供了一套实用工具,可帮助你创建和使用页面。你可以使用这些工具来操作页面配置或定义路由规则。

extendPages

在 Nuxt 中,路由是根据 app/pages 目录中的文件结构自动生成的。但是,在某些情况下,你可能希望自定义这些路由。例如,你可能需要为 Nuxt 未生成的动态页面添加路由、删除现有路由或修改路由的配置。对于此类自定义,Nuxt 提供了 extendPages 功能,允许你扩展和更改页面配置。

观看 Vue School 关于 extendPages 的视频。

使用

import { createResolver, defineNuxtModule, extendPages } from '@nuxt/kit'

export default defineNuxtModule({
  setup (options) {
    const { resolve } = createResolver(import.meta.url)

    extendPages((pages) => {
      pages.unshift({
        name: 'prismic-preview',
        path: '/preview',
        file: resolve('runtime/preview.vue'),
      })
    })
  },
})

类型

function extendPages (callback: (pages: NuxtPage[]) => void): void

参数

callback:一个函数,将使用页面配置进行调用。你可以通过添加、删除或修改其元素来更改此数组。注意:你应该直接修改提供的页面数组,因为对复制的数组所做的更改将不会反映在配置中。

属性类型必需描述
namestringfalse路由的名称。对于编程导航和识别路由很有用。
pathstringfalse路由 URL 路径。如果未设置,Nuxt 将从文件位置推断它。
文件stringfalse用作路由组件的 Vue 文件的路径。
metaRecord<string, any>false路由的自定义元数据。可在布局、中间件或导航守卫中使用。
aliasstring[] | stringfalse路由的一个或多个别名路径。用于支持多个 URL。
重定向RouteLocationRawfalse路由的重定向规则。支持命名路由、对象或字符串路径。
子路由NuxtPage[]false此路由下的嵌套子路由,用于布局或视图嵌套。

extendRouteRules

Nuxt 由Nitro服务器引擎提供支持。借助 Nitro,你可以将高级逻辑直接合并到配置中,这对于重定向、代理、缓存和向路由添加标头等操作非常有用。此配置通过将路由模式与特定路由设置相关联来工作。

你可以在Nitro 文档.
观看 Vue School 关于添加路由规则和路由中间件的视频。

使用

import { createResolver, defineNuxtModule, extendPages, extendRouteRules } from '@nuxt/kit'

export default defineNuxtModule({
  setup (options) {
    const { resolve } = createResolver(import.meta.url)

    extendPages((pages) => {
      pages.unshift({
        name: 'preview-new',
        path: '/preview-new',
        file: resolve('runtime/preview.vue'),
      })
    })

    extendRouteRules('/preview', {
      redirect: {
        to: '/preview-new',
        statusCode: 302,
      },
    })

    extendRouteRules('/preview-new', {
      cache: {
        maxAge: 60 * 60 * 24 * 7,
      },
    })
  },
})

类型

function extendRouteRules (route: string, rule: NitroRouteConfig, options?: ExtendRouteRulesOptions): void

参数

route:要匹配的路由模式。
rule:要应用于匹配路由的路由规则配置。

关于路由规则配置,你可以在混合渲染 > 路由规则中获取更多详细信息。

options:一个对象,用于传递给路由配置。如果 override 设置为 true,它将覆盖现有路由配置。

名称类型默认描述
overridebooleanfalse覆盖路由规则配置,默认为 false

addRouteMiddleware

注册路由中间件以供所有路由或特定路由使用。

路由中间件也可以通过 addRouteMiddleware 可组合项在插件中定义。

路由中间件文档中阅读更多关于路由中间件的信息。
观看 Vue School 关于添加路由规则和路由中间件的视频。

使用

import { addRouteMiddleware, createResolver, defineNuxtModule } from '@nuxt/kit'

export default defineNuxtModule({
  setup () {
    const { resolve } = createResolver(import.meta.url)

    addRouteMiddleware({
      name: 'auth',
      path: resolve('runtime/auth'),
      global: true,
    }, { prepend: true })
  },
})

类型

function addRouteMiddleware (input: NuxtMiddleware | NuxtMiddleware[], options?: AddRouteMiddlewareOptions): void

参数

input:一个中间件对象或一个包含以下属性的中间件对象数组

属性类型必需描述
namestringtrue中间件的名称。
pathstringtrue中间件的文件路径。
globalbooleanfalse如果设置为 true,则将中间件应用于所有路由。

options:一个包含以下属性的对象

属性类型默认描述
overridebooleanfalse如果为 true,则替换同名中间件。
prependbooleanfalse如果为 true,则将中间件前置于现有中间件之前。