Configuration
ts-node supports a variety of options which can be specified via tsconfig.json, as CLI flags, as environment variables, or programmatically.
For a complete list, see Options.
CLI flags
ts-node CLI flags must come before the entrypoint script. For example:
shell
shell
Via tsconfig.json (recommended)
ts-node automatically finds and loads tsconfig.json.  Most ts-node options can be specified in a "ts-node" object using their programmatic, camelCase names. We recommend this because it works even when you cannot pass CLI flags, such as node --require ts-node/register and when using shebangs.
Use --skipProject to skip loading the tsconfig.json.  Use --project to explicitly specify the path to a tsconfig.json.
When searching, it is resolved using the same search behavior as tsc. By default, this search is performed relative to the entrypoint script. In --cwdMode or if no entrypoint is specified -- for example when using the REPL -- the search is performed relative to --cwd / process.cwd().
You can use this sample configuration as a starting point:
tsconfig.jsonjson
tsconfig.jsonjson
Our bundled JSON schema lists all compatible options.
@tsconfig/bases
@tsconfig/bases maintains recommended configurations for several node versions. As a convenience, these are bundled with ts-node.
tsconfig.jsonjson
tsconfig.jsonjson
Default config
If no tsconfig.json is loaded from disk, ts-node will use the newest recommended defaults from
@tsconfig/bases compatible with your node and typescript versions.
With the latest node and typescript, this is @tsconfig/node16.
Older versions of typescript are incompatible with @tsconfig/node16.  In those cases we will use an older default configuration.
When in doubt, ts-node --showConfig will log the configuration being used, and ts-node -vv will log node and typescript versions.
node flags
node flags must be passed directly to node; they cannot be passed to the ts-node binary nor can they be specified in tsconfig.json
We recommend using the NODE_OPTIONS environment variable to pass options to node.
shell
shell
Alternatively, you can invoke node directly and install ts-node via --require/-r
shell
shell