跳至主要内容

Node.js 内置 API

Deno Deploy 原生支持通过 `node:` 说明符导入内置 Node.js 模块,例如 `fs`、`path` 和 `http`。这允许在 Deno Deploy 中运行最初为 Node.js 编写的代码,而无需更改。

以下是一个在 Deno Deploy 上运行的 Node.js HTTP 服务器示例

import { createServer } from "node:http";
import process from "node:process";

const server = createServer((req, res) => {
  const message = `Hello from ${process.env.DENO_REGION} at ${new Date()}`;
  res.end(message);
});

server.listen(8080);

_您可以在这里查看此示例的实际运行情况:https://dash.deno.com/playground/node-specifiers_

使用 `node:` 说明符时,Deno Deploy 的所有其他功能仍然可用。例如,即使使用 Node.js 模块,您也可以使用 `Deno.env` 访问环境变量。您还可以像往常一样从外部 URL 导入其他 ESM 模块。

以下 Node.js 模块可用

  • assert
  • assert/strict
  • async_hooks
  • buffer
  • child_process
  • cluster
  • console
  • constants
  • crypto
  • dgram
  • diagnostics_channel
  • dns
  • dns/promises
  • domain
  • events
  • fs
  • fs/promises
  • http
  • http2
  • https
  • module
  • net
  • os
  • path
  • path/posix
  • path/win32
  • perf_hooks
  • process
  • punycode
  • querystring
  • readline
  • stream
  • stream/consumers
  • stream/promises
  • stream/web
  • string_decoder
  • sys
  • timers
  • timers/promises
  • tls
  • tty
  • url
  • util
  • util/types
  • v8
  • vm
  • worker_threads
  • zlib

在大多数情况下,这些模块的行为应该与 Node.js 相同。由于 Deno Deploy 的沙箱行为,某些功能不可用

  • 使用 `child_process` 执行二进制文件
  • 使用 `worker_threads` 生成工作线程
  • 使用 `vm` 创建上下文并评估代码

注意:Node.js 模块的模拟足以满足大多数用例,但尚未完美。如果您遇到任何问题,请打开问题.