Nitro
Nitro - это TypeScript фреймворк с открытым исходный кодом для создания сверхбыстрых веб-серверов. Nuxt (и, по желанию, Nuxt Bridge) использует Nitro в качестве своего серверного движка. Вы можете использовать useNitro для доступа к экземпляру Nitro, addServerHandler для добавления обработчика сервера, addDevServerHandler для добавления обработчика сервера, который будет использоваться только в режиме разработки, addServerPlugin для добавления плагина для расширения поведения Nitro во время выполнения и addPrerenderRoutes для добавления маршрутов для предварительного рендеринга Nitro.
addServerHandler
Adds a Nitro server handler. Use this if you want to create server middleware or a custom route.
Usage
import { createResolver, defineNuxtModule, addServerHandler } from '@nuxt/kit'
export default defineNuxtModule({
setup(options) {
const { resolve } = createResolver(import.meta.url)
addServerHandler({
route: '/robots.txt',
handler: resolve('./runtime/robots.get')
})
}
})
Тип
function addServerHandler (handler: NitroEventHandler): void
Параметры
handler: A handler object with the following properties:
| Property | Type | Required | Description |
|---|---|---|---|
handler | string | true | Path to event handler. |
route | string | false | Path prefix or route. If an empty string used, will be used as a middleware. |
middleware | boolean | false | Specifies this is a middleware handler. Middleware are called on every route and should normally return nothing to pass to the next handlers. |
lazy | boolean | false | Use lazy loading to import the handler. This is useful when you only want to load the handler on demand. |
method | string | false | Router method matcher. If handler name contains method name, it will be used as a default value. |
Примеры
Basic Usage
You can use addServerHandler to add a server handler from your module.
import { createResolver, defineNuxtModule, addServerHandler } from '@nuxt/kit'
export default defineNuxtModule({
setup(options) {
const { resolve } = createResolver(import.meta.url)
addServerHandler({
route: '/robots.txt',
handler: resolve('./runtime/robots.get')
})
}
})
export default defineEventHandler(() => {
return {
body: `User-agent: *\nDisallow: /`
}
})
When you access /robots.txt, it will return the following response:
User-agent: *
Disallow: /
addDevServerHandler
Adds a Nitro server handler to be used only in development mode. This handler will be excluded from production build.
Usage
import { defineEventHandler } from 'h3'
import { createResolver, defineNuxtModule, addDevServerHandler } from '@nuxt/kit'
export default defineNuxtModule({
setup() {
addDevServerHandler({
handler: defineEventHandler(() => {
return {
body: `Ответ, сгенерированный в ${new Date().toISOString()}`
}
}),
route: '/_handler'
})
}
})
Type
// @errors: 2391
import type { NitroDevEventHandler } from 'nitropack'
// ---cut---
function addDevServerHandler (handler: NitroDevEventHandler): void
Parameters
handler: A handler object with the following properties:
| Property | Type | Required | Description |
|---|---|---|---|
handler | EventHandler | true | Event handler. |
route | string | false | Path prefix or route. If an empty string used, will be used as a middleware. |
Examples
Basic Usage
In some cases, you may want to create a server handler specifically for development purposes, such as a Tailwind config viewer.
import { joinURL } from 'ufo'
import { defineNuxtModule, addDevServerHandler } from '@nuxt/kit'
export default defineNuxtModule({
async setup(options, nuxt) {
const route = joinURL(nuxt.options.app?.baseURL, '/_tailwind')
// @ts-ignore
const createServer = await import('tailwind-config-viewer/server/index.js').then(r => r.default || r) as any
const viewerDevMiddleware = createServer({ tailwindConfigProvider: () => options, routerPrefix: route }).asMiddleware()
addDevServerHandler({ route, handler: viewerDevMiddleware })
}
})
useNitro
Возвращает экземпляр Nitro.
useNitro() только после хука ready.Usage
import { defineNuxtModule, useNitro } from '@nuxt/kit'
export default defineNuxtModule({
setup(options, nuxt) {
const resolver = createResolver(import.meta.url)
nuxt.hook('ready', () => {
const nitro = useNitro()
// Do something with Nitro instance
})
}
})
Type
function useNitro (): Nitro
addServerPlugin
Добавление плагина для расширения runtime-поведения Nitro.
Usage
import { createResolver, defineNuxtModule, addServerPlugin } from '@nuxt/kit'
export default defineNuxtModule({
setup() {
const { resolve } = createResolver(import.meta.url)
addServerPlugin(resolve('./runtime/plugin.ts'))
}
})
Тип
function addServerPlugin (plugin: string): void
Параметры
| Property | Type | Required | Description |
|---|---|---|---|
plugin | string | true | Path to the plugin. The plugin must export a default function that accepts the Nitro instance as an argument. |
Примеры
import { createResolver, defineNuxtModule, addServerPlugin } from '@nuxt/kit'
export default defineNuxtModule({
setup() {
const { resolve } = createResolver(import.meta.url)
addServerPlugin(resolve('./runtime/plugin.ts'))
}
})
export default defineNitroPlugin((nitroApp) => {
nitroApp.hooks.hook("request", (event) => {
console.log("при запросе", event.path);
});
nitroApp.hooks.hook("beforeResponse", (event, { body }) => {
console.log("при ответе", event.path, { body });
});
nitroApp.hooks.hook("afterResponse", (event, { body }) => {
console.log("после ответа", event.path, { body });
});
});
addPrerenderRoutes
Add routes to be prerendered to Nitro.
Usage
import { defineNuxtModule, addPrerenderRoutes } from '@nuxt/kit'
export default defineNuxtModule({
meta: {
name: 'nuxt-sitemap',
configKey: 'sitemap',
},
defaults: {
sitemapUrl: '/sitemap.xml',
prerender: true,
},
setup(options) {
if (options.prerender) {
addPrerenderRoutes(options.sitemapUrl)
}
}
})
Type
function addPrerenderRoutes (routes: string | string[]): void
Parameters
| Property | Type | Required | Description |
|---|---|---|---|
routes | string | string[] | true | A route or an array of routes to prerender. |
addServerImports
Add imports to the server. It makes your imports available in Nitro without the need to import them manually.
Usage
import { defineNuxtModule, createResolver, addServerImports } from '@nuxt/kit'
export default defineNuxtModule({
setup(options) {
const names = [
'useStoryblok',
'useStoryblokApi',
'useStoryblokBridge',
'renderRichText',
'RichTextSchema'
]
names.forEach((name) =>
addServerImports({ name, as: name, from: '@storyblok/vue' })
)
}
})
Type
function addServerImports (dirs: Import | Import[]): void
Parameters
imports: An object or an array of objects with the following properties:
| Property | Type | Required | Description |
|---|---|---|---|
name | string | true | Import name to be detected. |
from | string | true | Module specifier to import from. |
priority | number | false | Priority of the import; if multiple imports have the same name, the one with the highest priority will be used. |
disabled | boolean | false | If this import is disabled. |
meta | Record<string, any> | false | Metadata of the import. |
type | boolean | false | If this import is a pure type import. |
typeFrom | string | false | Use this as the from value when generating type declarations. |
as | string | false | Import as this name. |
addServerImportsDir
Добавьте директорию, которая будет сканироваться Nitro на предмет автоимпорта.
Usage
import { defineNuxtModule, createResolver, addServerImportsDir } from '@nuxt/kit'
export default defineNuxtModule({
meta: {
name: 'my-module',
configKey: 'myModule',
},
setup(options) {
const { resolve } = createResolver(import.meta.url)
addServerImportsDir(resolve('./runtime/server/composables'))
}
})
Type
function addServerImportsDir (dirs: string | string[], opts: { prepend?: boolean }): void
Параметры
| Property | Type | Required | Description |
|---|---|---|---|
dirs | string | string[] | true | A directory or an array of directories to register to be scanned by Nitro. |
opts | { prepend?: boolean } | false | Options for the import directory. If prepend is true, the directory is added to the beginning of the scan list. |
Примеры
You can use addServerImportsDir to add a directory to be scanned by Nitro. This is useful when you want Nitro to auto-import functions from a custom server directory.
import { defineNuxtModule, createResolver, addServerImportsDir } from '@nuxt/kit'
export default defineNuxtModule({
meta: {
name: 'my-module',
configKey: 'myModule',
},
setup(options) {
const { resolve } = createResolver(import.meta.url)
addServerImportsDir(resolve('./runtime/server/composables'))
}
})
export function useApiSecret() {
const { apiSecret } = useRuntimeConfig()
return apiSecret
}
You can then use the useApiSecret function in your server code:
const useApiSecret = (): string => ''
// ---cut---
export default defineEventHandler(() => {
const apiSecret = useApiSecret()
// Do something with the apiSecret
})
addServerScanDir
Добавьте директории, которые будут сканироваться Nitro. Nitro будет проверять подкаталоги, которые будут зарегистрированы
так же, как и папка ~/server.
~/server/api, ~/server/routes, ~/server/middleware, and ~/server/utils are scanned.Usage
import { defineNuxtModule, createResolver, addServerScanDir } from '@nuxt/kit'
export default defineNuxtModule({
meta: {
name: 'my-module',
configKey: 'myModule',
},
setup(options) {
const { resolve } = createResolver(import.meta.url)
addServerScanDir(resolve('./runtime/server'))
}
})
Тип
function addServerScanDir (dirs: string | string[], opts: { prepend?: boolean }): void
Параметры
| Property | Type | Required | Description |
|---|---|---|---|
dirs | string | string[] | true | A directory or an array of directories to register to be scanned for by Nitro as server dirs. |
opts | { prepend?: boolean } | false | Options for the import directory. If prepend is true, the directory is added to the beginning of the scan list. |
Примеры
You can use addServerScanDir to add a directory to be scanned by Nitro. This is useful when you want to add a custom server directory.
import { defineNuxtModule, createResolver, addServerScanDir } from '@nuxt/kit'
export default defineNuxtModule({
meta: {
name: 'my-module',
configKey: 'myModule',
},
setup(options) {
const { resolve } = createResolver(import.meta.url)
addServerScanDir(resolve('./runtime/server'))
}
})
export function hello() {
return 'Hello from server utils!'
}
You can then use the hello function in your server code.
function hello() {
return 'Hello from server utils!'
}
// ---cut---
export default defineEventHandler(() => {
return hello() // Hello from server utils!
})
Шаблоны
Nuxt Kit предоставляет набор утилит, которые помогают вам работать с шаблонами. Эти функции позволяют вам генерировать дополнительные файлы во время разработки и сборки.
Resolving
Nuxt Kit предоставляет набор утилит, которые помогут вам разрешать пути. Эти функции позволяют вам разрешать пути, относительные к текущему модулю, с неизвестным именем или расширением.