⚠️WARNING⚠️: All content in this article uses Node.js experimental features. Please make sure you are using a version of Node.js that supports the features mentioned in this article. And remember that experimental features can change in future versions of Node.js.
Running TypeScript Natively
In the previous articles, we learned how to run TypeScript code using transpilation and with a runner. In this article, we will learn how to run TypeScript code using Node.js itself.
Running TypeScript code with Node.js
Since V22.6.0, Node.js has experimental support for some TypeScript syntax via "type stripping". You can write code that's valid TypeScript directly in Node.js without the need to transpile it first.
The --experimental-strip-types
flag tells Node.js to strip the type annotations from the TypeScript code before running it.
node --experimental-strip-types example.ts
And that's it! You can now run TypeScript code directly in Node.js without the need to transpile it first, and use TypeScript to catch type-related errors.
In V22.7.0 this experimental support was extended to transform TypeScript-only syntax, like enum
s and namespace
, with the addition of the --experimental-transform-types
flag. Enabling --experimental-transform-types
automatically implies that --experimental-strip-types
is enabled, so there's no need to use both flags in the same command:
node --experimental-transform-types another-example.ts
From V23 onwards, the --experimental-strip-types
flag is enabled by default (you can disable it via the --no-experimental-strip-types
flag), enabling you to run any supported syntax, so running files like the one below with node file.ts
is supported:
function foo(bar: number): string {
return 'hello';
}
However, running any code that requires transformations, like the code below still needs the use of --experimental-transform-types
:
enum MyEnum {
A,
B,
}
console.log(MyEnum.A);
Future versions of Node.js will include support for TypeScript without the need for a command line flag.
Limitations
At the time of writing, the experimental support for TypeScript in Node.js has some limitations.
You can get more information on the API docs.
Configuration
The Node.js TypeScript loader (Amaro) does not need or use tsconfig.json
to run TypeScript code.
We recommend configuring your editor and tsc
to reflect Node.js behavior by creating a tsconfig.json
using the compilerOptions
listed here, as well as using TypeScript version 5.7 or higher.
Important notes
Thanks to all the contributors who have made this feature possible. We hope that this feature will be stable and available in the LTS version of Node.js soon.
We can understand that this feature is experimental and has some limitations; if that doesn't suit your use-case, please use something else, or contribute a fix. Bug reports are also welcome, please keep in mind the project is run by volunteers, without warranty of any kind, so please be patient if you can't contribute the fix yourself.