How to fix “TypeScript emitted no output” error

When working with TypeScript, a common error you might come across is the message "TypeScript emitted no output." This error typically means that TypeScript hasn't produced any JavaScript files, either because of a configuration issue, a source file error, or a few other possible causes. This guide will discuss the various reasons why you might encounter this error and how to fix it.

Investigating the error

The error message, at face value, indicates that TypeScript hasn't emitted any output files (typically JavaScript). But why? Let's delve into the common causes.

Incorrect tsconfig.json configuration

The configuration of your TypeScript project is controlled by a tsconfig.json file. If this file contains errors or is misconfigured, it could lead to no output.

  • "noEmit" option: Ensure that the "noEmit" option isn't set to true. If it's true, TypeScript will perform type-checking but won't generate any output files.
{ "compilerOptions": { "noEmit": false } }
  • Output directory: Ensure the "outDir" option points to a correct and accessible directory.
{ "compilerOptions": { "outDir": "./dist" } }

Source files issue

If you have an issue in one of your TypeScript source files, it can prevent the compiler from emitting JavaScript.

  • No source files: Ensure you have TypeScript files in your project. If the compiler doesn't find any .ts files, it won't emit anything.
  • Type errors: If your TypeScript code contains type errors, and the "noEmitOnError" option is set to true in your tsconfig.json, the compiler will not produce any output files.
{ "compilerOptions": { "noEmitOnError": true } }

Using isolatedModules flag without transpileOnly

The --isolatedModules flag ensures that every file can be safely transpiled without references to other files. If you use this flag, but you aren't using the --transpileOnly flag, it can cause the "TypeScript emitted no output" error.

Compiler bugs or third-party issues

Though rare, there's a possibility that a bug in the TypeScript compiler or an issue with a third-party tool or library is causing the problem. If you suspect this might be the case:

  • Check if any recent updates were made to your dependencies that might be causing the issue.
  • Look for open issues on the TypeScript GitHub repository or the repositories of any third-party tools you're using.
  • Consider rolling back to a previous, stable version of TypeScript or the tool in question.

Configuration overriding

It's possible that command line arguments or another configuration file might be overriding your tsconfig.json. Ensure that no other configurations interfere with your intended settings.

Fixing the error

Now that you've looked into the potential causes, here's how to address them:

Adjust your tsconfig.json

If the issue lies in your configuration:

  1. Ensure "noEmit" is set to false.
  2. Check the "outDir" and ensure it's correct.
  3. If you don't want type errors to halt the output, set "noEmitOnError" to false.

Review your source files

  1. Confirm that you have .ts files in your project.
  2. Fix any type errors in your code. Tools like ESLint with TypeScript support can be instrumental in catching these.

Use flags judiciously

If you're using the --isolatedModules flag, ensure you're also using --transpileOnly.

Check third-party tools and libraries

Update or rollback versions of tools or libraries if they are the cause of the issue. Remember, always check their documentation or GitHub issues for known problems.

Ensure no configuration overriding

Ensure that there's no conflicting command line argument or another configuration file causing the issue. If you're working within a larger team or using tools like Basedash to view and edit data from your database, ensure that shared configurations or integrations aren't causing the problem.

Wrapping up

"TypeScript emitted no output" can initially be a perplexing error. However, by methodically checking configurations, source files, flags, and third-party interactions, you can quickly isolate and fix the problem, ensuring a smooth TypeScript to JavaScript transpilation process.

Invite only

The next generation of charts.

Coming soon.

The next generation of charts. Coming soon.

The next generation of charts. Coming soon.

Fast. Opinionated. Collaborative. Local-first. Keyboard centric. Crafted to the last pixel. We've got 50 slots for Alpha access.