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 totrue
. 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 totrue
in yourtsconfig.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:
- Ensure
"noEmit"
is set tofalse
. - Check the
"outDir"
and ensure it's correct. - If you don't want type errors to halt the output, set
"noEmitOnError"
tofalse
.
Review your source files
- Confirm that you have
.ts
files in your project. - 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
Fast. Opinionated. Collaborative. Local-first. Keyboard centric. Crafted to the last pixel. We've got 50 slots for Alpha access.
How to turn webpages into editable canvases with a JavaScript bookmarklet
Kris Lachance
How to fix the "not all code paths return a value" issue in TypeScript
Kris Lachance
Working with WebSockets in Node.js using TypeScript
Kris Lachance
Type Annotations Can Only Be Used in TypeScript Files
Kris Lachance
Guide to TypeScript Recursive Type
Kris Lachance
How to Configure Knex.js with TypeScript
Kris Lachance