September 16, 2015

Converting JavaScript to TypeScript – Common Problems

Converting JavaScript code to TypeScript

Here at theCodeCampus and w11k we are using TypeScript in web projects for 12 months now. Our experiences with TypeScript are overwhelming so far! Using TypeScript is a huge improvement over a JavaScript-based development, especially in larger projects.

One of TypeScript’s advantages and often communicated characteristic is that its syntax is a (typed) superset of JavaScript. Hence, existing JavaScript code is valid TypeScript code. So far, so good! The selling point is that you can easily take existing JavaScript code and convert it to TypeScript, simply by changing the file extension from ‘js’ to ‘ts’.

Problem 1: Inferred ‘any type’

When new TypeScript users try this in practice, they often experience this error message:

The reason for this is quite simple: When e.g. a method parameter does not declare a type (which isn’t possible when the code used to be valid JavaScript), the TypeScript compiler warns that the ‘any type’ was inferred. Let’s say your method looks like this:

The solution is to simply explicitly add a type, either the ‘any type’ or a more precise one. Both declaration below would work:

 

Another solution is to change the behavior of the TypeScript compiler. How to do this, depends on the way you used to invoke the compiler. The command line tool ‘tsc’ uses the flag ‘–noImplicitAny’ to toggle this behavior. If you use a tsconfig.json (what you hopefully do), you can alter the compiler flags there:

However, I highly recommend to leave this flag on or respectively to add this flag to the ‘tsc’ invocation. After all, you want the compiler to assist you in writing better code and adding reasonable type annotations to your variables is one part of it.

Problem 2: Inferred Structural Types for Object Literals

Take the following perfectly valid JavaScript code:

We first initialize the object ‘obj’ with 2 properties. Then, based on a condition, we add another property ‘key3’. If the condition is false, the expression ‘obj.key3’ will evaluate to ‘undefined’. All this is common JavaScript code. However, if we pass this to the TypeScript compiler, we get an error message:

The reason for this is that our object literal used to initialize the ‘obj’ variable also creates a ‘structural type’ consisting of two properties: ‘key1’ and ‘key2’. When we try to assign the property ‘key3’, the compiler rightfully complains that this type has no property ‘key3’.

There are two possible solutions for this. We can add this property to the structural type:

 

Or, we declare the variable ‘obj’ with the ‘any type’:

 

If possible, I recommend to always choose the first solution.

 

 

Related Posts

Roman Roelofsen
Developer at thecodecampus </>

Roman is an expert in the development of database driven web-applications. He is sharing his longstanding expertise in open source projects, technical articles and conference talks.


Leave a Reply

Add code to your comment in Markdown syntax.
Like this:
`inline example`

```
code block
example
```

Your email address will not be published.