Typescript装饰器是一种特殊类型的声明,可以附加到类声明、方法、属性或参数上,以提供元数据和修改类的行为。装饰器在Typescript中使用@符号进行标记,有四种类型的装饰器:类装饰器、属性装饰器、方法装饰器和参数装饰器。
- 类装饰器 类装饰器在类声明之前声明,并且接受一个参数,该参数是类的构造函数。类装饰器可以用来修改或增强类的行为,例如添加新属性、方法或修改原有的属性和方法。
function classDecorator(target: any) { // do something with the class } @classDecorator class MyClass { // class definition }
- 属性装饰器 属性装饰器在属性声明之前声明,并且接受两个参数,第一个参数是类的原型对象,第二个参数是属性的名称。属性装饰器可以用来修改类的属性,例如添加新属性或修改属性的行为。
function propertyDecorator(target: any, propertyKey: string) { // do something with the property } class MyClass { @propertyDecorator myProperty: string; }
- 方法装饰器 方法装饰器在方法声明之前声明,并且接受三个参数,第一个参数是类的原型对象,第二个参数是方法的名称,第三个参数是方法的属性描述符。方法装饰器可以用来修改类的方法,例如添加新方法或修改方法的行为。
function methodDecorator(target: any, methodName: string, descriptor: PropertyDescriptor) { // do something with the method } class MyClass { @methodDecorator myMethod() { // method definition } }
- 参数装饰器 参数装饰器在参数声明之前声明,并且接受三个参数,第一个参数是类的原型对象,第二个参数是方法的名称,第三个参数是参数在方法参数列表中的索引。参数装饰器可以用来修改方法的参数,例如验证参数或添加额外的逻辑。
function parameterDecorator(target: any, methodName: string, parameterIndex: number) { // do something with the parameter } class MyClass { myMethod(@parameterDecorator param1: string, @parameterDecorator param2: number) { // method definition } }
总的来说,Typescript装饰器提供了一种强大的方式来修改类的行为和添加元数据,可以帮助开发者更好地组织和维护代码。