A lot of times, there are features you don’t know, so maybe, in your case, the “Decorator” is one of them.
This is the first post in a series about TypeScript Decorators where I want to give you a practical introduction to them.
What is a Decorator? Which types are there? Why would you want to use a Decorator and in what kind of situations would you use it?
What Is a Decorator?
What are Decorators? Well, think about the meaning of the word “decoration” and you are pretty close.
The TypeScript website describes it as:
“A Decorator is a special kind of declaration that can be attached to a class declaration, method, accessor, property, or parameter.”
I would describe it as “a special declaration to add extra features on an existing class declaration, method, accessor, property, or parameter.”
If you are using Angular, chances are that you are already using Decorators like
@Inject. This will help a bit with getting a better understanding of Decorators.
Which Decorators Are There?
To describe what Decorators do in TypeScript, we need to dive deeper into each type. There are a few different types of decorators.
- Class Decorator (current post).
- Property Decorator (next post).
- Method Decorator (will come later).
- Accessor @ Decorator (will come later).
- Parameter Decorator (will come later).
Let’s start with the class Decorator. To visualize that, we are going to build a (fictive) piece of the Lord of the Rings game.
To play the game, we need a lot of characters. Some can be the character you play with, some are for the scene around it.
This is the class for a
Character. It has an
type. The type is bound to the enum
In the LOTR, you have a wide variety of characters. We are going to use the class Decorator to make two character types, the Hobbit and the Elf.
Both of the classes extend the
Character class we defined on top because the Elf and Hobbit both have their own strengths, weaknesses, and capabilities.
In the Hobbit Decorator, we override some properties that are specific if our player is a Hobbit. The same for the Elf.
A Decorator is a function that returns a new constructor which extends the
constructor of the class. In this constructor, we add or overwrite existing properties/methods to the classes we apply the Decorator on.
Sadly enough, we can’t get the information from the original constructor to use that information. I learned that after trying for a day! If you know another method, please write it in a comment so I can include it.
When you want to add the Decorator to a class, you define it as
@hobbitDec above the class you want it to be applied to.
When you console log that in the browser, you should see the information combined with the information from the
If we want our player to be an Elf, we do the same thing as for the Hobbit.
We apply the
@elfDec on the
PlayerCharacter class to add the player type information.
Log the information in the console and you see that the correct information is applied.
If you want to give your Decorator some options, conditionals, or other extra data, you need to use a Decorator factory.
A Decorator factory is a function that returns the expression that will be called by the Decorator. Let’s take the Hobbit Decorator, for example.
If we want to use that Decorator with an option, we add it like
If we try to get the data from the player to the console, we see that the
condition attribute is added to the result.
When Would You Use the Class Decorator?
Well, I think it’s pretty simple. When you want to overwrite or add a bunch of properties/methods to a class, it can be a good idea to use the class Decorator.
What is the difference between Decorator and extending a class?
Maybe you’re thinking that you could also extend the
Elf class at the
PlayerCharacter class. Yes, that is also possible!
But the difference, when using a class Decorator instead of extending a class, is that when you extend a class, you will and can manipulate the data from the extended class most of the time.
In contrast to extending a class, the class Decorator will always be on top of the class. So you can’t manipulate the data from the Decorator inside your class.
So, if you use a class Decorator, know that you can cause some major side-effects you didn’t think of.
I hope that your now up-to-date with the TypeScript class Decorator and that you learned how to use it. But also what is not possible with it.
In the next post, I’m going to show you how to use the TypeScript property Decorator.
If you have any questions, please post them in the comments 👍.
Read my other posts
Dive into GraphQL w/ Apollo Client by building a SpaceX 🚀 app in Angular 8
_I know that this sounds odder than it is, but using GraphQL in an Angular 8 application with Apollo Client feels like…_itnext.io