Deploy
自定义预设
如果你想使用 Nitro 不支持的提供者,或想修改现有的提供者,你可以在项目中创建一个本地自定义预设。
自定义预设是本地文件,包含定义构建器配置的预设条目和一个运行时入口点。
自定义本地预设支持是一个实验性功能。
示例
查看 unjs/nitro-preset-starter 以获取现成的模板。
首先,我们需要在本地目录 preset/nitro.config.ts
中定义我们的预设入口点。
./preset/nitro.config.ts
import type { NitroPreset } from "nitropack";
import { fileURLToPath } from "node:url"
export default <NitroPreset>{
// extends: "node-server", // 你可以扩展现有的预设
entry: fileURLToPath(new URL("./entry.ts", import.meta.url)),
hooks: {
compiled() {
// ...
},
},
};
入口点将被你的服务器或提供者使用,你可以完全自定义它的行为。
import "#internal/nitro/virtual/polyfill";
const nitroApp = useNitroApp();
export default {
fetch(request: Request) {
const url = new URL(request.url);
return nitroApp.localFetch(url.pathname + url.search, {
context: {},
host: url.hostname,
protocol: url.protocol,
method: request.method,
headers: request.headers,
body: undefined,
});
},
};
然后在你的 nitro 配置文件中,你可以使用你的自定义预设。
export default defineNitroConfig({
preset: "./preset",
});
直接参考 Nitro 源代码 以更好地理解预设和入口点。