372

When I try to start my app on Heroku I got the following stack trace. It is just a basic ts.app like you see with ts-node and nodemon.

I am really interested in what the answer is going to be.

2020-05-30T00:03:12.201106+00:00 heroku[web.1]: Starting process with command `npm start`
2020-05-30T00:03:14.405285+00:00 app[web.1]: 
2020-05-30T00:03:14.405303+00:00 app[web.1]: > discordtoornamentmanager@1.0.0 start /app
2020-05-30T00:03:14.405303+00:00 app[web.1]: > ts-node src/App.ts
2020-05-30T00:03:14.405304+00:00 app[web.1]: 
2020-05-30T00:03:14.833655+00:00 app[web.1]: (node:23) ExperimentalWarning: The ESM module loader is experimental.
2020-05-30T00:03:14.839311+00:00 app[web.1]: TypeError [ERR_UNKNOWN_FILE_EXTENSION]: Unknown file extension ".ts" for /app/src/App.ts
2020-05-30T00:03:14.839312+00:00 app[web.1]:     at Loader.defaultGetFormat [as _getFormat] (internal/modules/esm/get_format.js:65:15)
2020-05-30T00:03:14.839314+00:00 app[web.1]:     at Loader.getFormat (internal/modules/esm/loader.js:113:42)
2020-05-30T00:03:14.839315+00:00 app[web.1]:     at Loader.getModuleJob (internal/modules/esm/loader.js:244:31)
2020-05-30T00:03:14.839315+00:00 app[web.1]:     at processTicksAndRejections (internal/process/task_queues.js:97:5)
2020-05-30T00:03:14.839316+00:00 app[web.1]:     at Loader.import (internal/modules/esm/loader.js:178:17)
2020-05-30T00:03:14.847801+00:00 app[web.1]: npm ERR! code ELIFECYCLE
2020-05-30T00:03:14.847998+00:00 app[web.1]: npm ERR! errno 1
2020-05-30T00:03:14.848957+00:00 app[web.1]: npm ERR! discordtoornamentmanager@1.0.0 start: `ts-node src/App.ts`
2020-05-30T00:03:14.849050+00:00 app[web.1]: npm ERR! Exit status 1
2020-05-30T00:03:14.849172+00:00 app[web.1]: npm ERR! 
2020-05-30T00:03:14.849254+00:00 app[web.1]: npm ERR! Failed at the discordtoornamentmanager@1.0.0 start script.
2020-05-30T00:03:14.849337+00:00 app[web.1]: npm ERR! This is probably not a problem with npm. There is likely additional logging output above.
2020-05-30T00:03:14.854859+00:00 app[web.1]: 
2020-05-30T00:03:14.854998+00:00 app[web.1]: npm ERR! A complete log of this run can be found in:
2020-05-30T00:03:14.855069+00:00 app[web.1]: npm ERR!     /app/.npm/_logs/2020-05-30T00_03_14_850Z-debug.log
2020-05-30T00:03:14.907689+00:00 heroku[web.1]: Process exited with status 1
2020-05-30T00:03:14.943718+00:00 heroku[web.1]: State changed from starting to crashed

This is my package.json

{
   "name": "discordtoornamentmanager",
   "version": "1.0.0",
   "description": "",
   "main": "dist/app.js",
   "type": "module",
   "scripts": {
      "test": "echo \"Error: no test specified\" && exit 1",
      "dev": "nodemon -x ts-node src/App.ts",
      "start": "ts-node src/App.ts"
   },
   "keywords": [],
   "author": "",
   "license": "ISC",
   "dependencies": {
      "@types/node": "^14.0.5",
      "axios": "^0.19.2",
      "discord.js": "^12.2.0",
      "pg": "^8.2.1",
      "reflect-metadata": "^0.1.10",
      "typeorm": "0.2.25",
      "typescript": "^3.9.3",
      "nodemon": "^2.0.4",
      "ts-node": "8.10.1"

   }
}

And this is my tsconfig

{
   "compilerOptions": {
      "lib": [
         "es6"
      ],
      "target": "es6",
      "module": "commonjs",
      "moduleResolution": "node",
      "outDir": "dist",
      "resolveJsonModule": true,
      "emitDecoratorMetadata": true,
      "esModuleInterop": true,
      "experimentalDecorators": true,
      "sourceMap": true
   },
   "include": ["src/**/*.ts"],
   "exclude": ["node_modules", "**/*.spec.ts"]
}
Elizar Pongracz
  • 3,783
  • 2
  • 7
  • 7
  • Lots of people are facing this issue https://stackoverflow.com/questions/65097694/to-load-an-es-module-set-type-module-in-the-package-json-or-use-the-mjs-e – giorgio79 Apr 22 '21 at 18:15
  • It is way way down in the answers list but in 2023 `tsx` seems to just work whereas `ts-node` gets bogged down in experimental features and even then often won't work. – Partly Cloudy Sep 01 '23 at 10:13

29 Answers29

448

Remove "type": "module" from package.json


https://github.com/TypeStrong/ts-node/issues/935

https://github.com/TypeStrong/ts-node/issues/1007#issuecomment-1163471306


If you don't want to remove "type": "module" (for example if you're using import statements in your .ts which allows the inference of types from modules), then you can use the following option in tsconfig.json:

{
  "compilerOptions": {
    "esModuleInterop": true,
  }
}

And then you can start the server with the config using ts-node.

Install:

npm install -g ts-node

Run:

ts-node-esm my_server.ts
AgedPeanuts
  • 145
  • 1
  • 16
vadimk7
  • 6,559
  • 1
  • 12
  • 15
  • 4
    It seems here is a problem with es modules and ts-node. Here is another issue https://github.com/TypeStrong/ts-node/issues/1007 for esm supports feedback. You can try workaround from *usage* part. Also, `The ESM module loader is experimental` so of course it's unstable approach. – vadimk7 Jun 02 '20 at 08:22
  • 180
    Removing `"type": "module"` gives me `To load an ES module, set "type": "module" in the package.json` for a script I use `import { ... } form '../'` in. – Dan Dascalescu Jan 31 '21 at 23:31
  • 12
    @DanDascalescu, you are right. Unfortunately, it's not possible to use ESM without `"type": "module"`. The described solution works because the author mentioned: `"module": "commonjs"` in his tsconfig.json :) otherwise, you can try hop into [1007](https://github.com/TypeStrong/ts-node/issues/1007) – vadimk7 Feb 01 '21 at 06:47
  • 19
    @wormsparty exactly! I'm still in it – Jerry Green Apr 04 '21 at 07:36
  • 1
    @wormsparty, did you find a solution in the end? – Nick Darvey Apr 04 '21 at 11:08
  • Yes. What I was doing was try and run a Typescript file with something like `ts-node myfile.ts`, and that made these errors. What I did is put my script in an existing Angular project and execute it when I press some button, and everything worked OK – wormsparty Apr 05 '21 at 08:18
  • 6
    Well, I dont have an angular project. Just a regular folder with ts files and trying to use VSCode with it – giorgio79 Apr 22 '21 at 18:15
  • @wormsparty [Escape the loop](https://stackoverflow.com/a/63719868/8211365) – tejasvi88 May 15 '21 at 15:17
  • 4
    this solution did not work for me....still unknown file extension – IonicMan Aug 04 '21 at 15:21
  • 184
    "esModuleInterop": true is already there in tsconfig file, still getting this error. – Shiv Aug 12 '21 at 15:58
  • I added `"esModuleInterop": true` to my tsconfig.json, now my terminal explodes with errors `error TS2349: This expression is not callable. Type 'typeof e' has no call signatures. A namespace-style import cannot be called or constructed, and will cause a failure at runtime. Type 'typeof serveStatic' has no call signatures.` etc. – Jeremy Thille Dec 10 '21 at 07:56
  • using ts-node the .ts file ran without the "esModuleInterop": true in tsconfig – younes zeboudj Feb 01 '22 at 17:26
  • 2
    however, how could I make `vscode` run `ts-node my_server.ts` after hitting the "run" UI button ? – zzzgoo Feb 27 '22 at 10:29
  • 4
    I can't remove it because I'm using [top-level `await`](https://github.com/tc39/proposal-top-level-await) – Boris Verkhovskiy Apr 24 '22 at 06:23
  • Any update, using es interop didn't work when running npx ts-node src/index.ts – JohnWick May 12 '22 at 20:27
  • 48
    Try running `ts-node` with the `--esm` flag. That fixed the `ERR_UNKNOWN_FILE_EXTENSION` error for me. I'm using Node 16.15.1 btw. ex: `ts-node --esm myfile.ts` – joelwat Jun 10 '22 at 23:42
  • Can be solved by ts-node and base configuration as described https://blog.appsignal.com/2022/01/19/how-to-set-up-a-nodejs-project-with-typescript.html , here is my answer based on it https://stackoverflow.com/a/72901378/504082 – TechGeorgii Jul 07 '22 at 16:44
  • 2
    The `ts-node` config options defined in [this answer](https://stackoverflow.com/a/65163089/2518231) solved for me. In `tsconfig.json` add: `"ts-node": { "esm": true, "experimentalSpecifierResolution": true }` – Matthew Herbst Jul 07 '22 at 18:56
  • The module option is there for a reason and some of us want to use it. Here's something that worked for me on 2022. Just compiled my ts with `"module": "ES2020"` and `"sourceMap": true`, then focused my `index.ts` file and pressed F5 with a break point in it. No `launch.json` was needed. – Juan Aug 21 '22 at 13:44
  • I had to restore the `"type": "module"` from `package.json` while using the `--esm` flag. – David Nov 14 '22 at 06:15
  • 3
    @MatthewHerbst 's answer works for me, except I have to set "experimentalSpecifierResolution" to "node" instead of true. – Erik Z Mar 17 '23 at 14:06
  • 3
    Wild that this answer has 400 upvote but doesn't actually work. Maybe it did once but as of May 2023 it doesn't. – Andy May 24 '23 at 14:55
  • Yep, I've gone through every suggestion here and ts-node-esm is still giving me 'unknown file extension: .ts'. – user3896248 Jul 19 '23 at 20:49
  • The solution that does work in 2023 is adding: ``` "ts-node": { "esm": true, "experimentalSpecifierResolution": "node" } ``` to tsconfig.json (instead of running by `ts-node-esm`) – Sinisa Rudan Aug 11 '23 at 21:38
224

use

node --loader ts-node/esm ./my-script.ts

// OR

ts-node --esm ./my-script.ts

instead of

ts-node ./my-script.ts
Eddy
  • 3,623
  • 37
  • 44
buzuosheng
  • 2,389
  • 1
  • 4
  • 3
  • 11
    what is ts-node/esm? No description at https://github.com/bluelovers/ws-esm-ts-node – giorgio79 Apr 20 '21 at 08:01
  • 3
    more info is here [https://github.com/TypeStrong/ts-node/issues/1007](https://github.com/TypeStrong/ts-node/issues/1007) – buzuosheng Apr 21 '21 at 11:43
  • 2
    For me this is the right answer. If I want to work with modules, removing the `types = module` is no solution. A workaround is the tsconfig module option in the script call to be overwritten with commonjs. But that is also unpleasant. – Alex Sedeke Apr 24 '21 at 19:55
  • 9
    To run it with nodemon we can use environment variables. The call could then look something like this : `NODE_OPTIONS='--no-warnings --loader ts-node/esm' nodemon --watch 'src/**/*' -e ts,tsx --exec ts-node ./server.ts` – Alex Sedeke Apr 24 '21 at 20:36
  • This worked, now I can run individual typescript files! – Jay Douglass Jul 22 '21 at 01:23
  • @AlexanderVu's suggestion was exactly what I needed. Thanks. – batjko Sep 11 '21 at 00:01
  • This answer MAY stop working later this month... beware of node 16.10 https://github.com/TypeStrong/ts-node/issues/1372 – Ray Foss Oct 19 '21 at 17:28
  • This is working for me. I want to add that: 1. need to install the ts-node package, can't do `npx ts-node` as I used to do 2. need to have a `ts-config.json`, even though all my files are js files – ZYinMD Nov 24 '21 at 13:02
  • 7
    Why does this work? – Scott Coates Dec 17 '21 at 03:41
  • 18
    You can also use `ts-node --esm ./my-script.ts` – abraj Mar 12 '22 at 11:24
  • 1
    This worked for me, but I needed to make sure to import modules with a .js extension e.g. `import { StoreLibrary } from './src/StoreServer.js' even though they were .ts files. Hope this helps anyone who still can't resolve files. – thomas88wp Mar 19 '22 at 22:41
  • 1
    Also for those using nodemon, adding a nodemon.json file with `{ "execMap": { "ts": "node --loader ts-node/esm" }}` will make nodemon use ts-node with esm. – thomas88wp Mar 19 '22 at 22:42
110

MARCH 2022

USING: Node 16.6.2, ts-node v 10.7.0

What worked for me was having "type": "module" in package.json, and adding

node --experimental-specifier-resolution=node --loader ts-node/esm ./src/app.ts

tsconfig.json:

{
    "compilerOptions": {
      "module": "ESNext",
      "esModuleInterop": true,
      "target": "ESNext",
      "moduleResolution": "Node",
      "outDir": "dist",
      "forceConsistentCasingInFileNames": true,
      "noFallthroughCasesInSwitch": true,
      "isolatedModules": false,
      "strict": true,
      "noImplicitAny": true,
      "useUnknownInCatchVariables": false,
      "inlineSourceMap": true
    },
    "ts-node": {
        "esm": true
    },
    "lib": ["esnext"]
}

Credits to @FelipePlets for the useful answer here

EDIT You may want to use a non-esnext option, as per the ts docs:

The special ESNext value refers to the highest version your version of TypeScript supports. This setting should be used with caution, since it doesn’t mean the same thing between different TypeScript versions and can make upgrades less predictable.

J.E.C.
  • 2,616
  • 2
  • 18
  • 21
89

Removing "type": "module" from package.json and adding:

  "compilerOptions": {
    "module": "CommonJS"
  },

In tsconfig.json fixed this for me.

Daniel_Knights
  • 7,940
  • 4
  • 21
  • 49
  • 3
    This solved my issue. I use Next.js + Express with TypeScript. Changed the "esnext" to "commonJS" from the "module" in tsconfig.json. Everything still works fine, I don't know whether there will be any break or not. – Sena Oct 13 '21 at 03:06
  • 55
    SyntaxError: Cannot use import statement outside a module – Phil Jan 01 '22 at 12:55
  • 2
    While it would seem to make no sense, in my particular case with this settings I can successfully run code with ES6 Import statements without any issue using ts-node. – Jacopo Tedeschi Jan 05 '22 at 23:12
  • 2
    so what's the benefit of using module = es2020? or how would it work? I can't seem to find a way to make it work – Fabien Warniez Apr 06 '22 at 23:00
  • I'm on a similar situation as "Sena", i'm also using Next.js and had to do that in order to run scripts locally and leverage the other .ts files in my repo. – kroe Dec 25 '22 at 18:13
73

Solution One

  1. Remove "type": "module" from package.json if it's added
  2. In tsconfig.json under the compilerOptions Set module property to CommonJS module: "CommonJS" and moduleResolution: "Node"

Solution Two

if the first one didn't work, or you have for some reason to keep module: "ESNext"

1- Add "type": "module" to package.json

2- Install ts-node npm i -g ts-node

3- Go to tsconfig.json and add the following:

{
    "compilerOptions": {
        "module": "ESNext",
        "moduleResolution": "Node",
        /* ... your props ... */
    },
    "ts-node": {
        "esm": true
    }
}

4- Run ts-node fileName.ts

45

Try adding this to your tsconfig.json

"ts-node": {
    "esm": true,
    "experimentalSpecifierResolution": "node",
}

I was able to fix with a tsconfig.json that looked something like:

{
  "compilerOptions": {
    "target": "es2022",
    "lib": ["ES2022"],
    "allowJs": true,
    "skipLibCheck": true,
    "esModuleInterop": true,
    "allowSyntheticDefaultImports": true,
    "strict": true,
    "forceConsistentCasingInFileNames": true,
    "noFallthroughCasesInSwitch": true,
    "module": "ES2022",
    "moduleResolution": "node",
    "resolveJsonModule": true,
    "isolatedModules": true,
    "noEmit": true,
  },
  "exclude": [
    "node_modules",
  ],
  "ts-node": {
    "esm": true,
    "experimentalSpecifierResolution": "node",
  }
}
gregolive
  • 451
  • 4
  • 5
25

I first came across this problem probably over a year ago, and ts-node has yet to fix it. None of the above solutions worked for me, and I have seemingly tried everything.

I just resorted to using tsc --outDir out file.ts and then running the file normally with node out/file.js, and then adding out to the .gitignore.

The thought behind ts-node is wonderful, just really sucks when it can't handle seemingly straightforward examples like this. Apologies the solution doesn't use ts-node, but I couldn't get it to work.

temporary_user_name
  • 35,956
  • 47
  • 141
  • 220
Sean Blonien
  • 387
  • 3
  • 5
20

In my opinion, this answer is best. https://stackoverflow.com/a/74608156/12894626

tldr; After years of trying to make ts-node work, just use tsx which works out of the box.

npm i -D tsx
npx tsx src/index.ts

npm: https://www.npmjs.com/package/tsx

  • Has 400k weekly downloads at the time of writing and rising.
wongz
  • 3,255
  • 2
  • 28
  • 55
  • 3
    I was literally about to cry because I couldn't get my stuff to build during an all-nighter before a major deadline. This saved my day big time!! Thanks! – lordphnx Jul 03 '23 at 20:01
19

I made some changes on my package.json & tsconfig.json.Finally, it worked for me!

  1. Add "type": "module" to package.json
  2. Uncomment "moduleResolution": "node" section in your tsconfig.json
  3. Change "module" section to "ESNEXT" in your tsconfig.json
  4. Then Just Run the main script with this node --loader ts-node/esm .\index.ts

tsconfig.json

{
"compilerOptions": {
/* Visit https://aka.ms/tsconfig.json to read more about this file */

/* Projects */
// "incremental": true,                              /* Enable incremental compilation */
// "composite": true,                                /* Enable constraints that allow a TypeScript project to be used with project references. */
// "tsBuildInfoFile": "./",                          /* Specify the folder for .tsbuildinfo incremental compilation files. */
// "disableSourceOfProjectReferenceRedirect": true,  /* Disable preferring source files instead of declaration files when referencing composite projects */
// "disableSolutionSearching": true,                 /* Opt a project out of multi-project reference checking when editing. */
// "disableReferencedProjectLoad": true,             /* Reduce the number of projects loaded automatically by TypeScript. */

/* Language and Environment */
"target": "es5",                                     /* Set the JavaScript language version for emitted JavaScript and include compatible library declarations. */
// "lib": [],                                        /* Specify a set of bundled library declaration files that describe the target runtime environment. */
// "jsx": "preserve",                                /* Specify what JSX code is generated. */
// "experimentalDecorators": true,                   /* Enable experimental support for TC39 stage 2 draft decorators. */
// "emitDecoratorMetadata": true,                    /* Emit design-type metadata for decorated declarations in source files. */
// "jsxFactory": "",                                 /* Specify the JSX factory function used when targeting React JSX emit, e.g. 'React.createElement' or 'h' */
// "jsxFragmentFactory": "",                         /* Specify the JSX Fragment reference used for fragments when targeting React JSX emit e.g. 'React.Fragment' or 'Fragment'. */
// "jsxImportSource": "",                            /* Specify module specifier used to import the JSX factory functions when using `jsx: react-jsx*`.` */
// "reactNamespace": "",                             /* Specify the object invoked for `createElement`. This only applies when targeting `react` JSX emit. */
// "noLib": true,                                    /* Disable including any library files, including the default lib.d.ts. */
// "useDefineForClassFields": true,                  /* Emit ECMAScript-standard-compliant class fields. */

/* Modules */
"module": "ESNEXT",  // ****HERE                          /* Specify what module code is generated. */
// "rootDir": "./",                                  /* Specify the root folder within your source files. */
"moduleResolution": "node",   // ****HERE                     /* Specify how TypeScript looks up a file from a given module specifier. */
// "baseUrl": "./",                                  /* Specify the base directory to resolve non-relative module names. */
// "paths": {},                                      /* Specify a set of entries that re-map imports to additional lookup locations. */
// "rootDirs": [],                                   /* Allow multiple folders to be treated as one when resolving modules. */
// "typeRoots": [],                                  /* Specify multiple folders that act like `./node_modules/@types`. */
// "types": [],                                      /* Specify type package names to be included without being referenced in a source file. */
// "allowUmdGlobalAccess": true,                     /* Allow accessing UMD globals from modules. */
// "resolveJsonModule": true,                        /* Enable importing .json files */
// "noResolve": true,                                /* Disallow `import`s, `require`s or `<reference>`s from expanding the number of files TypeScript should add to a project. */

/* JavaScript Support */
// "allowJs": true,                                  /* Allow JavaScript files to be a part of your program. Use the `checkJS` option to get errors from these files. */
// "checkJs": true,                                  /* Enable error reporting in type-checked JavaScript files. */
// "maxNodeModuleJsDepth": 1,                        /* Specify the maximum folder depth used for checking JavaScript files from `node_modules`. Only applicable with `allowJs`. */

/* Emit */
// "declaration": true,                              /* Generate .d.ts files from TypeScript and JavaScript files in your project. */
// "declarationMap": true,                           /* Create sourcemaps for d.ts files. */
// "emitDeclarationOnly": true,                      /* Only output d.ts files and not JavaScript files. */
// "sourceMap": true,                                /* Create source map files for emitted JavaScript files. */
// "outFile": "./",                                  /* Specify a file that bundles all outputs into one JavaScript file. If `declaration` is true, also designates a file that bundles all .d.ts output. */
// "outDir": "./",                                   /* Specify an output folder for all emitted files. */
// "removeComments": true,                           /* Disable emitting comments. */
// "noEmit": true,                                   /* Disable emitting files from a compilation. */
// "importHelpers": true,                            /* Allow importing helper functions from tslib once per project, instead of including them per-file. */
// "importsNotUsedAsValues": "remove",               /* Specify emit/checking behavior for imports that are only used for types */
// "downlevelIteration": true,                       /* Emit more compliant, but verbose and less performant JavaScript for iteration. */
// "sourceRoot": "",                                 /* Specify the root path for debuggers to find the reference source code. */
// "mapRoot": "",                                    /* Specify the location where debugger should locate map files instead of generated locations. */
// "inlineSourceMap": true,                          /* Include sourcemap files inside the emitted JavaScript. */
// "inlineSources": true,                            /* Include source code in the sourcemaps inside the emitted JavaScript. */
// "emitBOM": true,                                  /* Emit a UTF-8 Byte Order Mark (BOM) in the beginning of output files. */
// "newLine": "crlf",                                /* Set the newline character for emitting files. */
// "stripInternal": true,                            /* Disable emitting declarations that have `@internal` in their JSDoc comments. */
// "noEmitHelpers": true,                            /* Disable generating custom helper functions like `__extends` in compiled output. */
// "noEmitOnError": true,                            /* Disable emitting files if any type checking errors are reported. */
// "preserveConstEnums": true,                       /* Disable erasing `const enum` declarations in generated code. */
// "declarationDir": "./",                           /* Specify the output directory for generated declaration files. */

/* Interop Constraints */
// "isolatedModules": true,                          /* Ensure that each file can be safely transpiled without relying on other imports. */
// "allowSyntheticDefaultImports": true,             /* Allow 'import x from y' when a module doesn't have a default export. */
"esModuleInterop": true,                             /* Emit additional JavaScript to ease support for importing CommonJS modules. This enables `allowSyntheticDefaultImports` for type compatibility. */
// "preserveSymlinks": true,                         /* Disable resolving symlinks to their realpath. This correlates to the same flag in node. */
"forceConsistentCasingInFileNames": true,            /* Ensure that casing is correct in imports. */

/* Type Checking */
"strict": true,                                      /* Enable all strict type-checking options. */
// "noImplicitAny": true,                            /* Enable error reporting for expressions and declarations with an implied `any` type.. */
// "strictNullChecks": true,                         /* When type checking, take into account `null` and `undefined`. */
// "strictFunctionTypes": true,                      /* When assigning functions, check to ensure parameters and the return values are subtype-compatible. */
// "strictBindCallApply": true,                      /* Check that the arguments for `bind`, `call`, and `apply` methods match the original function. */
// "strictPropertyInitialization": true,             /* Check for class properties that are declared but not set in the constructor. */
// "noImplicitThis": true,                           /* Enable error reporting when `this` is given the type `any`. */
// "useUnknownInCatchVariables": true,               /* Type catch clause variables as 'unknown' instead of 'any'. */
// "alwaysStrict": true,                             /* Ensure 'use strict' is always emitted. */
// "noUnusedLocals": true,                           /* Enable error reporting when a local variables aren't read. */
// "noUnusedParameters": true,                       /* Raise an error when a function parameter isn't read */
// "exactOptionalPropertyTypes": true,               /* Interpret optional property types as written, rather than adding 'undefined'. */
// "noImplicitReturns": true,                        /* Enable error reporting for codepaths that do not explicitly return in a function. */
// "noFallthroughCasesInSwitch": true,               /* Enable error reporting for fallthrough cases in switch statements. */
// "noUncheckedIndexedAccess": true,                 /* Include 'undefined' in index signature results */
// "noImplicitOverride": true,                       /* Ensure overriding members in derived classes are marked with an override modifier. */
// "noPropertyAccessFromIndexSignature": true,       /* Enforces using indexed accessors for keys declared using an indexed type */
// "allowUnusedLabels": true,                        /* Disable error reporting for unused labels. */
// "allowUnreachableCode": true,                     /* Disable error reporting for unreachable code. */

/* Completeness */
// "skipDefaultLibCheck": true,                      /* Skip type checking .d.ts files that are included with TypeScript. */
"skipLibCheck": true                                 /* Skip type checking all .d.ts files. */
}}

package.json

{
"name": "async-with-ts",
"version": "1.0.0",
"main": "index.js",
"license": "MIT",
"type": "module", // ****HERE
"devDependencies": {
"@types/node-fetch": "^3.0.3",
"ts-node": "^10.2.1",
"typescript": "^4.4.2"
},
"dependencies": {
"node-fetch": "^3.0.0"
  }
}

You should be aware of using this command

node --loader ts-node/esm .\index.ts
aybasaran10
  • 335
  • 2
  • 7
12

After some experimentation with my ts-node/puppeteer configuration I came up with this:

package.json

{
    "type": "module",
    "scripts": {
        "start": "npx ts-node main.ts"
    },
    ...
}

tsconfig.json

{
    "ts-node": { "esm": true, "experimentalSpecifierResolution": "node" },
    "compilerOptions": {
        "esModuleInterop": true,
        "moduleResolution": "node",
        "module": "ESNext",
        ...
    },
    ...
}

Works great for running puppeteer in a TypeScript environment.
(Running NodeJS 19.0.0 with TypeScript 4.9.4 and ts-node 10.9.1)

donnikitos
  • 776
  • 1
  • 9
  • 18
6

You can use ts-node-esm instead of ts-node, keeping "type":"module" in package.json, and using import './module.js' in your .ts files.

Related: https://github.com/TypeStrong/ts-node/issues/1007

UPDATE:

This answer has an even better solution as allows to import modules without .js extension:

https://stackoverflow.com/a/65163089/1482990

drodsou
  • 2,970
  • 1
  • 21
  • 15
4

I tried to remove this error by following methods but FAILED : (1)- Using .mts extension. (2)- Using type:commonjs instead of type:module in package.json (this will not let you use 'import' in your TS file, However i wanted that, therefore i consider this try to be failed). (3)- Restarting the VS-Code

Then I tried the following and SUCCEEDED : (1)- Using --esm flag with ts-node command. e.g => npx ts-node --esm ./src/index.ts. (2) - Inside tsConfig.json, add another option after Compiler options' closing bracket named "ts-node" and set its "esm" option to "true", same as below :

{
  "compilerOptions": {
    "module": "ESNext",
    "moduleResolution": "Node",
    /* ... other props ... */
  },
  "ts-node": {
    "esm": true, /* ... Line to be added ... */
  } 
}
2

I followed advice given herein. I also had to uninstall lodash-es and install lodash instead to make it work.

danday74
  • 52,471
  • 49
  • 232
  • 283
2

Running ts-node with --esm worked for me.

For example:

ts-node --esm src/App.ts

That error is caused by trying to import modules, which without the ES Modules flag, ts-node doesn't support.

Chris Hayes
  • 11,505
  • 6
  • 33
  • 41
1

if your tsconfig.json contains "module": "ESNext". I have used the below script in my package.json. It worked.

 "start": "nodemon -e ts -w ./src -x npm run watch:serve",
 "watch:serve": "node --loader ts-node/esm src/server.ts",
Jordan
  • 39
  • 5
0

Update: Thanks to some maintainers, a working solution is now officially documented by webpack. Just take a small look at the official webpack documentation.

The second solution is similar to other answers here and works perfectly fine in my case.

Philipp Sonntag
  • 322
  • 2
  • 9
0

July 2022, with the use of ts-node

Node 16.14.2, ts-node 10.8.2

First install ts-node and base configuration

npm install ts-node --save-dev
npm install @tsconfig/node16 --save-dev

tsconfig.json:

{
    "extends": "@tsconfig/node16/tsconfig.json",
    "compilerOptions": {
        "resolveJsonModule": true
    },
    "include": [
        "main.ts"
        // here you can include another directories with sources
    ],
    "exclude": [
        "node_modules"
    ]
}

You can remove everything related to modules/compilation from package.json.

And then you can run your program as

ts-node ./main.ts
TechGeorgii
  • 414
  • 4
  • 14
0

For me (node version 14), for some reason, the problem was that I install the serialize-error package and when I tried to import it to threw that error. To solve it I downgraded the version of the package from 11.0.0 to 8.0.0.

Max
  • 907
  • 2
  • 13
  • 27
0

If you use PowerShell on VS Code on Windows 11 try to use this command:

ts-node-esm.cmd .\my_script.ts

after this solution: https://stackoverflow.com/a/62099904/8967481

  • Your answer could be improved with additional supporting information. Please [edit] to add further details, such as citations or documentation, so that others can confirm that your answer is correct. You can find more information on how to write good answers [in the help center](/help/how-to-answer). – Community Oct 11 '22 at 11:51
0

For anyone who is running into this issue while trying run an script in an NX project.

# For apps
ts-node --project tsconfig.app.json $yourFilePath

# For libraries
ts-node --project tsconfig.lib.json $yourFilePath

# For tests
ts-node --project tsconfig.spec.json $yourFilePath
Stuart Clark
  • 611
  • 8
  • 13
0

@vadimk7 wasn't far off, my solution was to change my file extension to .mts and then use ts-node-esm myfile.mts

  • This does not provide an answer to the question. Once you have sufficient [reputation](https://stackoverflow.com/help/whats-reputation) you will be able to [comment on any post](https://stackoverflow.com/help/privileges/comment); instead, [provide answers that don't require clarification from the asker](https://meta.stackexchange.com/questions/214173/why-do-i-need-50-reputation-to-comment-what-can-i-do-instead). - [From Review](/review/late-answers/33747910) – Hardik Shah Feb 06 '23 at 11:52
0

After trying all the solutions here, it still didn't work. Then I changed my run script from npx ts-node --esm index.ts to ts-node --project tsconfig.json index.ts and it worked!

-2

Add this to tsconfig.json

{
  /* ... your props ... */

  "ts-node": {
    "compilerOptions": {
      "module": "CommonJS"
    }
  }
}
Mateusz
  • 27
  • 3
-3

before this:

node --loader ts-node/esm ./my-script.ts

I had to update ssri

npm update ssri --depth 5

Dharman
  • 30,962
  • 25
  • 85
  • 135
djossir
  • 73
  • 1
  • 6
-3

Not sure if this will help anyone but I fixed it by putting this at the start:

#!/usr/bin/env node
JudasMoses
  • 378
  • 4
  • 22
  • Really not sure why people aren't liking my answer to this question. It was a genuine solution when I had the exact same error. For a problem like this where the root cause could be range of issues more answers helps in my opinion. – JudasMoses May 13 '22 at 04:53
-3

I wanted to use ES modules instead of commonjs in my project. In addition to making some changes covered in other answers, the last need step for me was to add this to my compilerOptions in tsconfig.json:

"sourceMap": true,
Abir Taheer
  • 2,502
  • 3
  • 12
  • 34
Josh Diehl
  • 2,913
  • 2
  • 31
  • 43
-5

changing my

"moduleResolution": "node", 

to

"moduleResolution": "Node",

in package.json solved this for me

Recommence
  • 75
  • 1
  • 8
-6

In your package.json {Module:commonJS}, and tsconfig.json {module:commonJS},to ts-node youname.ts

  • As it’s currently written, your answer is unclear. Please [edit] to add additional details that will help others understand how this addresses the question asked. You can find more information on how to write good answers [in the help center](/help/how-to-answer). – Community Jan 18 '22 at 10:38
-6

I changed my imports from:

import blah from './modules/blah'

to

import blah from './modules.blah.js'