- assert 断言
- async_hooks 异步钩子
- async_hooks/context 异步上下文
- buffer 缓冲区
- C++插件
- C/C++插件(使用 Node-API)
- C++嵌入器
- child_process 子进程
- cluster 集群
- CLI 命令行
- console 控制台
- Corepack 核心包
- crypto 加密
- crypto/webcrypto 网络加密
- debugger 调试器
- deprecation 弃用
- dgram 数据报
- diagnostics_channel 诊断通道
- dns 域名服务器
- domain 域
- env 环境变量
- Error 错误
- events 事件触发器
- fs 文件系统
- global 全局变量
- http 超文本传输协议
- http2 超文本传输协议 2.0
- https 安全超文本传输协议
- inspector 检查器
- Intl 国际化
- module 模块
- module/cjs CommonJS 模块
- module/esm ECMAScript 模块
- module/package 包模块
- module/typescript TS 模块
- net 网络
- os 操作系统
- path 路径
- perf_hooks 性能钩子
- permission 权限
- process 进程
- punycode 域名代码
- querystring 查询字符串
- readline 逐行读取
- repl 交互式解释器
- report 诊断报告
- sea 单个可执行应用程序
Node.js v22.21.0 文档
- Node.js v22.21.0
- 目录
- 
      
      
        导航
      
      
 - assert 断言
- async_hooks 异步钩子
- async_hooks/context 异步上下文
- buffer 缓冲区
- C++插件
- C/C++插件(使用 Node-API)
- C++嵌入器
- child_process 子进程
- cluster 集群
- CLI 命令行
- console 控制台
- Corepack 核心包
- crypto 加密
- crypto/webcrypto 网络加密
- debugger 调试器
- deprecation 弃用
- dgram 数据报
- diagnostics_channel 诊断通道
- dns 域名服务器
- domain 域
- env 环境变量
- Error 错误
- events 事件触发器
- fs 文件系统
- global 全局变量
- http 超文本传输协议
- http2 超文本传输协议 2.0
- https 安全超文本传输协议
- inspector 检查器
- Intl 国际化
- module 模块
- module/cjs CommonJS 模块
- module/esm ECMAScript 模块
- module/package 包模块
- module/typescript TS 模块
- net 网络
- os 操作系统
- path 路径
- perf_hooks 性能钩子
- permission 权限
- process 进程
- punycode 域名代码
- querystring 查询字符串
- readline 逐行读取
- repl 交互式解释器
- report 诊断报告
- sea 单个可执行应用程序
 
- 其他版本
模块:TypeScript#>
¥Modules: TypeScript
¥Stability: 1.2 - Release candidate
启用#>
¥Enabling
有两种方法可以在 Node.js 中启用运行时 TypeScript 支持:
¥There are two ways to enable runtime TypeScript support in Node.js:
- 
对于 TypeScript 的所有语法和功能的 完全支持,包括使用任何版本的 TypeScript,请使用第三方包。 ¥For full support of all of TypeScript's syntax and features, including using any version of TypeScript, use a third-party package. 
- 
对于轻量级支持,你可以使用对 类型剥离 的内置支持。 ¥For lightweight support, you can use the built-in support for type stripping. 
完全支持 TypeScript#>
¥Full TypeScript support
要使用完全支持所有 TypeScript 功能(包括 tsconfig.json)的 TypeScript,你可以使用第三方包。这些说明使用 tsx 作为示例,但还有许多其他类似的库可用。
¥To use TypeScript with full support for all TypeScript features, including
tsconfig.json, you can use a third-party package. These instructions use
tsx as an example but there are many other similar libraries available.
- 
使用你为项目使用的任何包管理器将包安装为开发依赖。例如,对于 npm:¥Install the package as a development dependency using whatever package manager you're using for your project. For example, with npm:npm install --save-dev tsx
- 
然后你可以通过以下方式运行 TypeScript 代码: ¥Then you can run your TypeScript code via: npx tsx your-file.ts或者,你可以通过以下方式使用 node运行:¥Or alternatively, you can run with nodevia:node --import=tsx your-file.ts
类型剥离#>
¥Type stripping
--no-experimental-strip-types 标志会阻止 Node.js 运行 TypeScript 文件。默认情况下,Node.js 只会执行不包含需要转换的 TypeScript 功能的文件,例如枚举。Node.js 将用空格替换内联类型注释,并且不执行类型检查。要启用此类功能的转换,请使用标志 --experimental-transform-types。依赖于 tsconfig.json 中的设置的 TypeScript 功能(例如路径或将较新的 JavaScript 语法转换为较旧的标准)是故意不支持的。要获得完整的 TypeScript 支持,请参阅 完全支持 TypeScript。
¥The flag --no-experimental-strip-types prevents Node.js from running TypeScript
files. By default Node.js will execute only files that contain no
TypeScript features that require transformation, such as enums.
Node.js will replace inline type annotations with whitespace,
and no type checking is performed.
To enable the transformation of such features
use the flag --experimental-transform-types.
TypeScript features that depend on settings within tsconfig.json,
such as paths or converting newer JavaScript syntax to older standards, are
intentionally unsupported. To get full TypeScript support, see Full TypeScript support.
类型剥离功能设计为轻量级。通过有意不支持需要 JavaScript 代码生成的语法,并通过用空格替换内联类型,Node.js 可以在不需要源映射的情况下运行 TypeScript 代码。
¥The type stripping feature is designed to be lightweight. By intentionally not supporting syntaxes that require JavaScript code generation, and by replacing inline types with whitespace, Node.js can run TypeScript code without the need for source maps.
类型剥离与大多数版本的 TypeScript 兼容,但我们建议使用 5.8 或更新版本,并使用以下 tsconfig.json 设置:
¥Type stripping is compatible with most versions of TypeScript
but we recommend version 5.8 or newer with the following tsconfig.json settings:
{
  "compilerOptions": {
     "noEmit": true, // Optional - see note below
     "target": "esnext",
     "module": "nodenext",
     "rewriteRelativeImportExtensions": true,
     "erasableSyntaxOnly": true,
     "verbatimModuleSyntax": true
  }
} 如果你打算仅执行 *.ts 文件(例如构建脚本),请使用 noEmit 选项。如果你打算分发 *.js 文件,则不需要此标志。
¥Use the noEmit option if you intend to only execute *.ts files, for example
a build script. You won't need this flag if you intend to distribute *.js
files.
确定模块系统#>
¥Determining module system
Node.js 在 TypeScript 文件中支持 CommonJS 和 ES 模块 语法。Node.js 不会从一个模块系统转换为另一个模块系统;如果你希望代码作为 ES 模块运行,则必须使用 import 和 export 语法,如果你希望代码作为 CommonJS 运行,则必须使用 require 和 module.exports。
¥Node.js supports both CommonJS and ES Modules syntax in TypeScript
files. Node.js will not convert from one module system to another; if you want
your code to run as an ES module, you must use import and export syntax, and
if you want your code to run as CommonJS you must use require and
module.exports.
- 
.ts文件将由其模块系统确定 与.js文件相同。 要使用import和export语法,请将"type": "module"添加到最近的父级package.json。¥ .tsfiles will have their module system determined the same way as.jsfiles. To useimportandexportsyntax, add"type": "module"to the nearest parentpackage.json.
- 
.mts文件将始终作为 ES 模块运行,类似于.mjs文件。¥ .mtsfiles will always be run as ES modules, similar to.mjsfiles.
- 
.cts文件将始终作为 CommonJS 模块运行,类似于.cjs文件。¥ .ctsfiles will always be run as CommonJS modules, similar to.cjsfiles.
- 
.tsx文件不受支持。¥ .tsxfiles are unsupported.
与 JavaScript 文件一样,import 语句和 import() 表达式中的 文件扩展名是强制性的:import './file.ts',不是 import './file'。由于向后兼容,文件扩展名在 require() 调用中也是强制性的:require('./file.ts'),而不是 require('./file'),类似于 .cjs 扩展在 CommonJS 文件中的 require 调用中是必需的。
¥As in JavaScript files, file extensions are mandatory in import statements
and import() expressions: import './file.ts', not import './file'. Because
of backward compatibility, file extensions are also mandatory in require()
calls: require('./file.ts'), not require('./file'), similar to how the
.cjs extension is mandatory in require calls in CommonJS files.
tsconfig.json 选项 allowImportingTsExtensions 将允许 TypeScript 编译器 tsc 使用包含 .ts 扩展名的 import 说明符对文件进行类型检查。
¥The tsconfig.json option allowImportingTsExtensions will allow the
TypeScript compiler tsc to type-check files with import specifiers that
include the .ts extension.
TypeScript 功能#>
¥TypeScript features
由于 Node.js 仅删除内联类型,因此任何涉及用新 JavaScript 语法替换 TypeScript 语法的 TypeScript 功能都会出错,除非传递了标志 --experimental-transform-types。
¥Since Node.js is only removing inline types, any TypeScript features that
involve replacing TypeScript syntax with new JavaScript syntax will error,
unless the flag --experimental-transform-types is passed.
需要转换的最突出的功能是:
¥The most prominent features that require transformation are:
- 
Enum声明¥ Enumdeclarations
- 
带有运行时代码的 namespace¥ namespacewith runtime code
- 
带有运行时代码的旧 module¥legacy modulewith runtime code
- 
参数属性 ¥parameter properties 
- 
导入别名 ¥import aliases 
支持不包含运行时代码的 namespaces 和 module。此示例将正常工作:
¥namespaces and module that do not contain runtime code are supported.
This example will work correctly:
// This namespace is exporting a type
namespace TypeOnly {
   export type A = string;
} 这将导致 ERR_UNSUPPORTED_TYPESCRIPT_SYNTAX 错误:
¥This will result in ERR_UNSUPPORTED_TYPESCRIPT_SYNTAX error:
// This namespace is exporting a value
namespace A {
   export let x = 1
} 由于装饰器当前是 TC39 第 3 阶段提案,并且很快将得到 JavaScript 引擎的支持,因此它们不会被转换,并将导致解析器错误。这是一个暂时的限制,将来会得到解决。
¥Since Decorators are currently a TC39 Stage 3 proposal and will soon be supported by the JavaScript engine, they are not transformed and will result in a parser error. This is a temporary limitation and will be resolved in the future.
此外,Node.js 不读取 tsconfig.json 文件,也不支持依赖于 tsconfig.json 中的设置的功能,例如路径或将较新的 JavaScript 语法转换为较旧的标准。
¥In addition, Node.js does not read tsconfig.json files and does not support
features that depend on settings within tsconfig.json, such as paths or
converting newer JavaScript syntax into older standards.
导入没有 type 关键字的类型#>
¥Importing types without type keyword
由于类型剥离的性质,type 关键字对于正确剥离类型导入是必需的。如果没有 type 关键字,Node.js 会将导入视为值导入,这将导致运行时错误。tsconfig 选项 verbatimModuleSyntax 可用于匹配此行为。
¥Due to the nature of type stripping, the type keyword is necessary to
correctly strip type imports. Without the type keyword, Node.js will treat the
import as a value import, which will result in a runtime error. The tsconfig
option verbatimModuleSyntax can be used to match this behavior.
此示例将正常工作:
¥This example will work correctly:
import type { Type1, Type2 } from './module.ts';
import { fn, type FnParams } from './fn.ts'; 这将导致运行时错误:
¥This will result in a runtime error:
import { Type1, Type2 } from './module.ts';
import { fn, FnParams } from './fn.ts'; 非文件形式的输入#>
¥Non-file forms of input
可以为 --eval 和 STDIN 启用类型剥离。模块系统将由 --input-type 确定,就像 JavaScript 一样。
¥Type stripping can be enabled for --eval and STDIN. The module system
will be determined by --input-type, as it is for JavaScript.
REPL、--check 和 inspect 不支持 TypeScript 语法。
¥TypeScript syntax is unsupported in the REPL, --check, and
inspect.
源映射#>
¥Source maps
由于内联类型被空格替换,因此源映射对于堆栈跟踪中的正确行号来说不是必需的;并且 Node.js 不会生成它们。启用 --experimental-transform-types 时,默认情况下会启用源映射。
¥Since inline types are replaced by whitespace, source maps are unnecessary for
correct line numbers in stack traces; and Node.js does not generate them.
When --experimental-transform-types is enabled, source-maps
are enabled by default.
依赖中的类型剥离#>
¥Type stripping in dependencies
为了阻止包作者发布用 TypeScript 编写的包,Node.js 拒绝处理 node_modules 路径下文件夹中的 TypeScript 文件。
¥To discourage package authors from publishing packages written in TypeScript,
Node.js refuses to handle TypeScript files inside folders under a node_modules
path.
路径别名#>
¥Paths aliases
tsconfig "paths" 不会被转换,因此会产生错误。最接近的功能是 子路径导入,但限制是它们需要从 # 开始。
¥tsconfig "paths" won't be transformed and therefore produce an error. The closest
feature available is subpath imports with the limitation that they need to start
with #.
