Hey! in this short and quick note I’d recommend to everyone to use in the current or in the future typescript projects you are going to work on, I would say it’s not a new tip and most of you might know it already but it’s important in my opinion and enhance the readability of your code for other people specially new comers to the team.
Problem
Have you ever seen this look in your projects imports ../../../../../
or even sometimes more ../../../../../../../../../
I believe you did, since most people prefer the auto-import in their editors like vscode or webstorm or anyother one, I would give you a shortcut to convert your import statement for instance from this 👎:
to this elegant one 👌 even with auto-import:
Solution
The solution is very easy, just open your tsconfig.json
in your application and add 2 more properties in case you did’t find them already
First: baseUrl
Which refers to the directory that you need your application to consider as a root directry or a base url, it’s value might be src
folder or app
folder as you want.
Second: paths
Which holds an object of shortcuts for the TypeScript transpiler and editor checkers, in this case you want it to be kind of
this means that any import starts with @components
please search inside the corresponding folder or folders as you can see you can add more than one alias into the same key, just write more values to the array.
So the final example after adding them, the tsconfig.json
file should be as follow:
That’s it for the TypeScript, in fact I’m adding the @
sympol here just to remind myself while reading the code that this path is an alias to the original internal file in my application but you can name it whatever works for you.
Important Note: after adding such settings to the tsconfig file make sure to restart your editor to take effect of these changes.
In case you are using babel or webpack there are some similar configurations for both of them you can make as well to make sure that the trancpiler is working fine with the new paths.
Resources that might help:
Tot ziens 👋