decorator-reflect
v2.4.5
Published
装饰器反射库
Downloads
6
Maintainers
Readme
Decorator build + reflection tool
Use to create decorators or decorator factories (decorators with parameters), merge existing decorators, and get typescript class information (properties, methods, method parameters < limited typescript>, and their decorators and types < limited typescript>) just like Java reflection does.
The DecoratorBuilder build shows how to use @Test() or @Test when the factory of the decorator has no arguments
Environment
- node v12
Typescript Demo
Javascript Demo
- [email protected]
- babel v7+
- [email protected]
Installation
npm i decorator-reflect -s
API
import {ReflectUtil, DecoratorBuilder} from "decorator-reflect";
Usage
Basic Usage
import {ReflectUtil, DecoratorBuilder} from "decorator-reflect";
const Log = DecoratorBuilder.create()
.method((target, propertyKey, descriptor, option) => ({
...descriptor,
value: function(...args: object[]) {
console.time();
try {
console.log('call method:', propertyKey, ', paramaters:', args);
const returnValue = descriptor.value.apply(this, args)
console.log('call method:', propertyKey, ', return:', returnValue);
return returnValue;
} finally {
console.timeEnd();
}
}
})).build();
class Demo1Class {
constructor() {
}
@Log
public method() {
return 'test';
}
}
new Demo1Class().method()
import {ReflectUtil, DecoratorBuilder} from "decorator-reflect";
/**
* 创建装饰器工厂 TestAnnotation
*/
const TestAnnotation = DecoratorBuilder.create<string>()
.method(((target, propertyKey, descriptor, option, definition) => {
console.log('**********method');
console.log(target); // TestClass {}
console.log(propertyKey); // prop
console.log(option); // test property
console.log(definition);
/**
MethodDefinition {
decorators: [ DecoratorDefinition { type: [Function], option: 'test method' } ],
name: 'method',
parameters: [ ParameterDefinition { decorators: [], type: [Function: String] } ],
returnType: [Function: Boolean],
isStatic: false
}
*/
})).property(((target, propertyKey, option, definition) => {
console.log('**********property');
console.log(target); // [Function: TestClass]
console.log(propertyKey); // prop
console.log(option); // test property
console.log(definition);
/**
PropertyDefinition {
decorators: [ DecoratorDefinition { type: [Function], option: 'test property' } ],
type: [Function: Boolean],
name: 'prop',
isStatic: true
}
*/
})).parameter((target, propertyKey, parameterIndex, option, definition) => {
console.log('**********parameter');
console.log(target); // [Function: TestClass]
console.log(propertyKey); // undefined
console.log(parameterIndex); // 1
console.log(definition);
/**
ParameterDefinition {
decorators: [
DecoratorDefinition { type: [Function], option: 'test parameter' }
],
type: [Function: String]
}
*/
}).class((target, option, definition) => {
console.log('**********class');
console.log(target); // [Function: TestClass]
console.log(option); // test class
console.log(definition); // ClassDefinition
}).build();
const Test = DecoratorBuilder.create().class().build();
@Test()
@TestAnnotation('test class')
class TestClass {
@TestAnnotation('test property')
static prop?: boolean;
constructor(a: number, @TestAnnotation('test parameter') b: string) {
}
@TestAnnotation('test method')
method(a: string): boolean {
return true;
}
}
// Get reflection information
// console.log(ReflectUtil.getDefinition(TestClass));
Merge multiple existing decorators
import {DecoratorBuilder, ReflectUtil} from "decorator-reflect";
const Test: ClassDecorator = (target) => {
// do something
}
const Test2: ClassDecorator = (target) => {
// do something
}
const Test3: MethodDecorator = (target) => {
// do something
}
const TestWrapper = DecoratorBuilder.create().class(Test).class(Test2).method(Test3).build();
@TestWrapper()
class TestClass {
@TestWrapper()
test() {}
}
console.log(ReflectUtil.getDefinition(TestClass));
// export type ClassDefinition<T extends Function> = {
// name: string;
// type: T;
// decorators: DecoratorDefinition[];
// properties: PropertyDefinition[];
// methods: MethodDefinition[];
// parameters: ParameterDefinition[];
// }