TypeScriptのdecorator
仕様の変遷
種類
decoratorは通常の高階関数として定義できる
逆に言えば、ただの関数宣言だけ見れば、それがdecoratorして使用される関数なのかどうかは判断できない
data:image/s3,"s3://crabby-images/6909e/6909e479c8a80b7a95155552c64ee71be78e5662" alt="mrsekut mrsekut"
このように定義すると、
tsfunction color(value: string) {
return function (target) {
// ..
};
}
こう使える
tsclass C {
@color()
method() {..}
}
これ、常に必要になるわけじゃないんか
data:image/s3,"s3://crabby-images/6909e/6909e479c8a80b7a95155552c64ee71be78e5662" alt="mrsekut mrsekut"
ユースケース
ログ出力
確かにコレ良さそう
data:image/s3,"s3://crabby-images/6909e/6909e479c8a80b7a95155552c64ee71be78e5662" alt="mrsekut mrsekut"
method内に直接ログを書くんじゃなくて、decoratorを付与してログを出力できる
method内は、そのmethodに関する処理だけに集中できる
引数のvalidaiton
notEmptyStringかとか、Intかなどのvalidationができる
DI
classにしか使えないの?関数に対しては使えないの?なんで?
tscofig