The decorator in TypeScript is a feature that enables us to add meta data or business logic without having to change the orginal code format.
For example, when we have multiple classes with the same attribute name, type, with the same value, we can use the decorator to reduce redundancy
data:image/s3,"s3://crabby-images/8d99d/8d99d2df544f71a6e3da465822166f2919c49861" alt=""
How to Use It?
This feature is in test at the moment, so we need a set up to use this. Open the console and run the command shown below.
npx tsc --init
data:image/s3,"s3://crabby-images/79e2a/79e2a7fd3964d36826d1a4f6dafb7bbb4cad7241" alt=""
After running, a file called 'tsconfig.json' will be created. There are many options written in the file but we don't need any of them so if you want you can delete them all.
data:image/s3,"s3://crabby-images/affea/affea24c547c1b9819675ea310119240946f7a67" alt=""
To use the decorator add the option shown below
{
"compilerOptions": {
"experimentalDecorators": true
}
}
data:image/s3,"s3://crabby-images/28ab3/28ab307e02e055420b5e7b66986d01362ead74ea" alt=""
Go to the code file and create a decorator (basically it is a function with a function as a parameter). Add the decorator to the classes
function DecoTest(type:Function) {
type.prototype.type = 'number'
}
@DecoTest
class ClassOne {
type: string = 'number'
}
@DecoTest
class ClassTwo {
type: string = 'number'
}
console.log(new ClassOne().type)
console.log(new ClassTwo().type)
Compile the file
npx tsc
data:image/s3,"s3://crabby-images/a1506/a1506275c49b7108a260dec215b13f184217d3d0" alt=""
You will see that we can set up the types for both the classes without having to change them separately
data:image/s3,"s3://crabby-images/ebb5a/ebb5a6b0c74976cd7e1a850ff2a22696bd91f94f" alt=""
Adding Parameters
But the thing is it is not possible to change the value dinamically.
We can add another function to dinamically change the values for each class. Update the code as shown below.
function DecoTest(type:number) { // outer function -> gets parameters
return (output: Function) => { // inner function -> returns decorator
output.prototype.value = type
}
}
@DecoTest(1)
class ClassOne {
type: string = ''
value: number
}
@DecoTest(2)
class ClassTwo {
type: string = ''
value: number
}
Complie the file
data:image/s3,"s3://crabby-images/8a2e7/8a2e784a4a2390e64b395ca0fbf0a031c5f1f025" alt=""
Then you will see that each class returns a value that is passed as a parameter in the decorator annotation.
data:image/s3,"s3://crabby-images/62ef1/62ef195a9e058b938f5217013756450e8e06576d" alt=""
In this writing, we have seen how to use decorators in TypeScript.
Source Code
https://github.com/jin-co/web-mobile/tree/master/TypeScript
GitHub - jin-co/web-mobile
Contribute to jin-co/web-mobile development by creating an account on GitHub.
github.com
References
https://www.typescriptlang.org/tsconfig
TSConfig Reference - Docs on every TSConfig option
From allowJs to useDefineForClassFields the TSConfig reference includes information about all of the active compiler flags setting up a TypeScript project.
www.typescriptlang.org
'Frontend > TypeScript' 카테고리의 다른 글
Generic (9) | 2023.05.12 |
---|---|
Interface (0) | 2023.03.06 |
TypeScript (0) | 2023.03.06 |