Skip type checking of declaration files.
This can save time during compilation at the expense of type-system accuracy. For example, two libraries could define two copies of the same type
in an inconsistent way. Rather than doing a full check of all d.ts
files, TypeScript will type check the code you specifically refer to in your app's source code.
A common case where you might think to use skipLibCheck
is when there are two copies of a library's types in your node_modules
. In these cases, you should consider using a feature like yarn's resolutions to ensure there is only one copy of that dependency in your tree or investigate how to ensure there is only one copy by understanding the dependency resolution to fix the issue without additional tooling.
Another possibility is when you are migrating between TypeScript releases and the changes cause breakages in node_modules and the JS standard libraries which you do not want to deal with during the TypeScript update.
Note, that if these issues come from the TypeScript standard library you can replace the library using TypeScript 4.5's lib replacement technique.