装饰器使用

一、装饰器#
1.概念#
装饰器让程序员可以编写元信息以内省代码。装饰器的最佳使用场景是横切关注点——面向切面编程。
面向切面编程(AOP) 是一种编程范式,它允许我们分离横切关注点,藉此达到增加模块化程度的目标。它可以在不修改代码自身的前提下,给已有代码增加额外的行为(通知)。
装饰器是一种特殊的声明,可附加在类、方法、访问器、属性、参数声明上。
通俗的讲装饰器就是一个方法,可以注入到类、方法、属性参数上来扩展类、属性、方法、参数的功能。
2.相关表现#
装饰器使用 @expression 的形式,其中 expression 必须能够演算为在运行时调用的函数,其中包括装饰声明信息。
它起到了以声明式方法将元信息添加至已有代码的作用。
装饰器类型及其执行优先级为
- 类装饰器——优先级 4 (对象实例化,静态)
- 方法装饰器——优先级 2 (对象实例化,静态)
- 访问器或属性装饰器——优先级 3 (对象实例化,静态)
- 参数装饰器——优先级 1 (对象实例化,静态)
注意,如果装饰器应用于类构造函数的参数,那么不同装饰器的优先级为:参数装饰器 > 方法装饰器 > 访问器或参数装饰器 > 构造器参数装饰器 > 类装饰器。
二、 装饰器的分类#
- 类装饰器(Class decorators)
- 属性装饰器(Property decorators)
- 方法装饰器(Method decorators)
- 参数装饰器(Parameter decorators)
需要注意的是,若要启用实验性的装饰器特性,你必须在命令行或 tsconfig.json 里启用 experimentalDecorators 编译器选项:
命令行:
tsconfig.json:
三、类装饰器#
类装饰器声明:
类装饰器顾名思义,就是用来装饰类的。它接收一个参数:
- target: TFunction - 被装饰的类
看完第一眼后,是不是感觉都不好了。没事,我们马上来个例子:
上面的例子中,我们定义了 Greeter 类装饰器,同时我们使用了 @Greeter 语法糖,来使用装饰器。
友情提示:读者可以直接复制上面的代码,在 TypeScript Playground 中运行查看结果。
有的读者可能想问,例子中总是输出 Hello Semlinker! ,能自定义输出的问候语么 ?这个问题很好,答案是可以的。
具体实现如下:
四、属性装饰器#
属性装饰器声明:
属性装饰器顾名思义,用来装饰类的属性。它接收两个参数:
- target: Object - 被装饰的类
- propertyKey: string | symbol - 被装饰类的属性名
趁热打铁,马上来个例子热热身:
以上代码我们定义了一个 logProperty 函数,来跟踪用户对属性的操作,当代码成功运行后,在控制台会输出以下结果:
五、方法装饰器#
方法装饰器声明:
方法装饰器顾名思义,用来装饰类的方法。它接收三个参数:
- target: Object - 被装饰的类
- propertyKey: string | symbol - 方法名
- descriptor: TypePropertyDescript - 属性描述符
废话不多说,直接上例子:
以上代码成功运行后,控制台会输出以下结果:
下面我们来介绍一下参数装饰器。
六、参数装饰器#
参数装饰器声明:
参数装饰器顾名思义,是用来装饰函数参数,它接收三个参数:
- target: Object - 被装饰的类
- propertyKey: string | symbol - 方法名
- parameterIndex: number - 方法中参数的索引值
以上代码成功运行后,控制台会输出以下结果: