typeScript 装饰器
来源:互联网 发布:网络专供款烟机 编辑:程序博客网 时间:2024/06/10 13:12
装饰器是一种特殊类型的声明,它能够被附加到类声明,方法, 访问符,属性或参数上。 装饰器使用@expression
这种形式,expression
求值后必须为一个函数,它会在运行时被调用,被装饰的声明信息做为参数传入。
例如,有一个@sealed
装饰器,我们会这样定义sealed
函数:
function sealed(target) { // do something with "target" ...}
装饰器工厂
如果我们要定制一个修饰器如何应用到一个声明上,我们得写一个装饰器工厂函数。 装饰器工厂就是一个简单的函数,它返回一个表达式,以供装饰器在运行时调用。
我们可以通过下面的方式来写一个装饰器工厂函数:
function color(value: string) { // 这是一个装饰器工厂 return function (target) { // 这是装饰器 // do something with "target" and "value"... }}
装饰器组合
多个装饰器可以同时应用到一个声明上,就像下面的示例:
- 书写在同一行上:
@f @g x
- 书写在多行上:
@f@gx
当多个装饰器应用于一个声明上,它们求值方式与复合函数相似。在这个模型下,当复合f和g时,复合的结果(f ∘ g)(x)等同于f(g(x))。
同样的,在TypeScript里,当多个装饰器应用在一个声明上时会进行如下步骤的操作:
- 由上至下依次对装饰器表达式求值。
- 求值的结果会被当作函数,由下至上依次调用。
function f() { console.log("f(): evaluated"); return function (target, propertyKey: string, descriptor: PropertyDescriptor) { console.log("f(): called"); }}function g() { console.log("g(): evaluated"); return function (target, propertyKey: string, descriptor: PropertyDescriptor) { console.log("g(): called"); }}class C { @f() @g() method() {}}
在控制台里会打印出如下结果:
f(): evaluatedg(): evaluatedg(): calledf(): called
永远别忘了在装饰器后面加括号()
。
阅读全文
0 0
- typeScript 装饰器
- Typescript中的装饰器原理
- typescript
- TypeScript
- typeScript
- typescript
- TypeScript
- TypeScript
- typescript
- TypeScript
- TypeScript
- TypeScript
- TypeScript
- TypeScript
- TypeScript
- TypeScript
- typescript
- Typescript
- 简单粗暴的入门机器学习
- Wordpress插件开发过程
- 在几年后,程序员的薪资会一直这么高么?
- Spring Data Jpa 自定义 Repository EntityManager is null
- 在Centos 7 上 搭建 K8S --坑a)
- typeScript 装饰器
- 2017.11.7作业
- bash脚本中的单引号双引号与反引号
- C语言知识点
- 简单排序算法:直接插入排序(插入排序)
- Spring-data-redis操作redis知识总结
- Generative Adversarial Network (GAN) papers (不定期更新)
- kotlin学习笔记(二)
- 数据库找到数据填入excel中