ts-decorators-utils
What is it ?
Create the typescript decorator declaratively, Just like Java.
It also provides tools to implement 'reflection'
It can run on the web or in nodejs
Getting Start
install
npm i ts-decorator-utils
tsconfig.json
{
"compilerOptions": {
"outDir": "./dist",
"module": "commonjs",
"target": "es6",
"declaration": true,
"lib": [
"es6",
"dom",
"esnext"
],
"experimentalDecorators": true,
"emitDecoratorMetadata": true,
"strictNullChecks": true
},
"exclude": [
"node_modules",
"dist"
]
}
Notice 'experimentalDecorators' and 'emitDecoratorMetadata'
Create a decorator
Create the required location, parameters, and metadata
import {DecoratorFactoryBuilder} from 'ts-decorators-utils';
const Demo = DecoratorFactoryBuilder.create()
.class().method().property().parameter().build();
type Demo2MetadataValue = {
value: string | number;
}
type Demo2PropOption = {
value: string;
} | string | void;
type Demo2ParamOption = {
value1: number;
value2: number;
};
const Demo2 = DecoratorFactoryBuilder.create<Demo2MetadataValue>()
.property<Demo2PropOption>(option => typeof option === 'string' ? )
.parameter<Demo2ParamOption>()
.build();
Use decorators
@Demo()
class TestClass {
@Demo2('demo2PropTest')
@Demo()
public prop: string;
@Demo()
public staticProp: string;
constructor(num: number) {}
@Demo()
public method(@Demo() param: string) {}
@Demo()
public static staticMethod(): string {
return '';
}
}
Getting information is similar to Java reflection
import {DecoratorUtil} from 'ts-decorators-utils';
// Is there a specified decorator on the target on the class, Some will return true or Object, and none will return undefined
console.log(DecoratorUtil.getMetadata(Demo, TestClass)); // true
console.log(DecoratorUtil.getMetadata(Demo, TestClass, 'staticMethod')); // true
console.log(DecoratorUtil.getMetadata(Demo, TestClass, 'staticProp')); // true
console.log(DecoratorUtil.getMetadata(Demo, TestClass.prototype, 'prop')); // true
console.log(DecoratorUtil.getMetadata(Demo, TestClass.prototype, 'method')); // true
console.log(DecoratorUtil.getMetadata(Demo, TestClass.prototype)); // undefined
console.log(DecoratorUtil.getMetadata(Demo, TestClass, 'staticMethod2')); // undefined
console.log(DecoratorUtil.getMethods(TestClass)); // [ [ 'staticMethod', [ [Function: String] ], undefined ] ]
Demo1
import {DecoratorFactoryBuilder, DecoratorUtil} from 'ts-decorators-utils';
const Value = DecoratorFactoryBuilder.create()
.property().parameter().build();
class Demo {
@Value()
public a: string;
public test(@Value() b: string) {
}
}
console.log(DecoratorUtil.getMetadata(Value, Demo.prototype, 'a')); // true
console.log(DecoratorUtil.getMetadata(Value, Demo.prototype, 'test')); // undefined
console.log(DecoratorUtil.getMetadata(Value, Demo.prototype, 'test', 0)); // true
let metadataKey = Value.metadataKey; // is a Symbol Type
import {DecoratorFactoryBuilder, DecoratorUtil} from 'ts-decorators-utils';
const Value2 = DecoratorFactoryBuilder.create<string>()
.method<string>().class<string>().build();
@Value2('demo2')
class Demo2 {
@Value2('testStatic')
public static testStatic(a: number): void {
}
constructor(public a: string, public b: number) {}
@Value2('test')
public test(b: string): Date {
return new Date();
}
}
console.log(DecoratorUtil.getMetadata(Value2, Demo2)); // demo2
console.log(DecoratorUtil.getMetadata(Value2, Demo2.prototype, 'test')); // test
console.log(DecoratorUtil.getMetadata(Value2, Demo2, 'testStatic')); // testStatic
// 可以获得类中 使用装饰器的实例方法 集合
console.log(DecoratorUtil.getMethods(Demo2.prototype)); // [ [ 'test', [ [Function: String] ], [Function: Date] ] ]
// 可以获得类中 使用装饰器的实例属性 集合 返回类型 [string, Constructor][]
console.log(DecoratorUtil.getProperties(Demo2.prototype)); // []
// 可以获得类中 使用装饰器的静态属性 集合 返回类型 [string, Constructor[], Constructor][] 数组中元组对应 方法名,方法参数类型数组,方法返回类型
console.log(DecoratorUtil.getMethods(Demo2)); // [ [ 'testStatic', [ [Function: Number] ], undefined ] ]
// 可以获得类中 使用装饰器的静态属性 集合
console.log(DecoratorUtil.getProperties(Demo2)); // []