Nuxt Kit中的 Nitro 处理程序

avatar
cmdragon 渡劫
image image

扫描二维码关注或者微信搜一搜:编程智域 前端至全栈交流与成长

Nitro 是 Nuxt 3 的服务器引擎,支持多种运行环境。它允许你创建高性能的服务器端应用程序,处理各种 HTTP 请求,动态生成内容等。

2. 基本概念

  • 处理程序:函数,用于处理特定的 HTTP 请求或路由。
  • 路由:URL 路径,用于匹配处理程序。
  • 中间件:在处理请求前处理某些操作的函数,通常用于身份验证或请求修改。

3. 创建 Nuxt 3 项目

首先,在你的开发环境中创建一个新的 Nuxt 3 项目:

1
2
3
npx nuxi init my-nuxt-app
cd my-nuxt-app
npm install

4. 添加服务器处理程序

4.1 使用 addServerHandler

4.1.1 创建处理程序

  1. 在项目根目录下创建 module.ts 文件。
  2. 创建 runtime/robots.get.ts 文件来定义处理程序。
1
2
3
4
5
6
7
8
9
10
11
12
13
// module.ts
import { createResolver, defineNuxtModule, addServerHandler } from '@nuxt/kit';

export default defineNuxtModule({
setup(options) {
const resolver = createResolver(import.meta.url); // 解析路径

addServerHandler({
route: '/robots.txt', // 定义路由
handler: resolver.resolve('./runtime/robots.get.ts'), // 指向处理程序
});
}
});

4.1.2 定义处理程序

1
2
3
4
5
// runtime/robots.get.ts
export default defineEventHandler((event) => {
return `User-agent: *
Disallow: /`;
});

4.1.3 完整项目结构

1
2
3
4
5
my-nuxt-app/
├── module.ts
├── runtime/
│ └── robots.get.ts
└── nuxt.config.ts

4.2 运行项目

使用以下命令启动开发服务器:

1
npx nuxi dev

访问 http://localhost:3000/robots.txt,应该能看到处理程序返回的内容。

5. 添加开发处理程序

5.1 使用 addDevServerHandler

5.1.1 创建开发处理程序

在同一 module.ts 中添加开发专用的处理程序。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
// module.ts
import { createResolver, defineNuxtModule, addDevServerHandler } from '@nuxt/kit';

export default defineNuxtModule({
setup() {
const resolver = createResolver(import.meta.url);

addDevServerHandler({
handler: resolver.resolve('./runtime/timer.get.ts'), // 开发处理程序路径
route: '/_timer', // 路由
});
}
});

// runtime/timer.get.ts
export default defineEventHandler((event) => {
return { uptime: process.uptime() }; // 返回应用的运行时
});

5.2 测试开发处理程序

访问 http://localhost:3000/_timer 查看返回的运行时信息。

6. 使用 useNitro

6.1 获取 Nitro 实例

通过 useNitro 方法在 Nuxt 中使用 Nitro 实例。

1
2
3
4
5
6
7
8
9
10
11
// module.ts
import { defineNuxtModule, useNitro } from '@nuxt/kit';

export default defineNuxtModule({
setup() {
nuxt.hook('ready', () => {
const nitro = useNitro(); // 获取 Nitro 实例
console.log('Nitro Options:', nitro.options); // 打印 Nitro 配置信息
});
}
});

7. 添加 Nitro 插件

7.1 使用 addServerPlugin

通过 addServerPlugin 添加一个插件来扩展 Nitro 的功能。

7.1.1 创建插件

runtime/plugin.ts 文件中定义插件。

1
2
3
4
5
6
// runtime/plugin.ts
export default (nitro) => {
nitro.hooks.hook('render:route', (route) => {
console.log(`Rendering route: ${route}`); // 当路由被渲染时打印
});
};

7.1.2 注册插件

module.ts 中注册插件:

1
2
3
4
5
6
7
8
9
// module.ts
import { createResolver, defineNuxtModule, addServerPlugin } from '@nuxt/kit';

export default defineNuxtModule({
setup() {
const resolver = createResolver(import.meta.url);
addServerPlugin(resolver.resolve('./runtime/plugin.ts')); // 注册插件
}
});

8. 预渲染路由

8.1 使用 addPrerenderRoutes

可以为静态站点指定需要预渲染的路由。

1
2
3
4
5
6
7
8
9
import { defineNuxtModule, addPrerenderRoutes } from '@nuxt/kit';

export default defineNuxtModule({
setup(options) {
const routesToPrerender = ['/about', '/contact']; // 需要预渲染的路由

addPrerenderRoutes(routesToPrerender); // 添加预渲染路由
}
});

9. 最佳实践

  • 代码组织: 把模块、插件和处理程序分开,确保项目结构清晰。
  • 使用钩子: 利用 nuxt.hook 使代码在适当位置执行,尤其是处理服务器设置时。
  • 异常处理: 在处理程序中添加错误日志记录,以便在开发过程中调试。

余下文章内容请点击跳转至 个人博客页面 或者 扫码关注或者微信搜一搜:编程智域 前端至全栈交流与成长,阅读完整的文章:

往期文章归档: