TypeScript 装饰器

随着TypeScript和ES6里引入了类,在一些场景下我们需要额外的特性来支持标注或修改类及其成员。装饰器是一种特殊类型的声明,它能够被附加到类声明,方法,属性或参数上,可以修改类的行为。
通俗的讲,装饰器就是一个方法,可以注入到类、方法、属性、参数上来扩展类、方法、属性、参数的功能。
常见的装饰器有:普通装饰器(无法传参)、装饰器工厂(可传参)

装饰器工厂

如果我们要定制一个修饰器如何应用到一个声明上,我们得写一个装饰器工厂函数。 装饰器工厂就是一个简单的函数,它返回一个表达式,以供装饰器在运行时调用。

我们可以通过下面的方式来写一个装饰器工厂函数:

function color(value: string) { // 这是一个装饰器工厂
    return function (target) { //  这是装饰器
        // do something with "target" and "value"...
    }
}

装饰器组合

多个装饰器可以同时应用到一个声明上,就像下面的示例:

  • 书写在同一行上:
@f @g x
  • 书写在多行上:
@f
@g
x

当多个装饰器应用于一个声明上,它们求值方式与复合函数相似。在这个模型下,当复合fg时,复合的结果(f ∘ g)(x)等同于f(g(x))。下面的修饰器的执行顺序的例子中会举例说明。

装饰器类型 (五种装饰器)

  • 类装饰器
  • 属性装饰器
  • 方法装饰器
  • 函数参数装饰器
  • 访问器装饰器

一、类装饰器 

类装饰器在类声明之前被声明(紧靠着类声明)。 类装饰器应用于类构造函数,可以用来监视,修改或替换类定义。 类装饰器不能用在声明文件中( .d.ts),也不能用在任何外部上下文中(比如declare的类)。

类装饰器表达式会在运行时当作函数被调用,类的构造函数作为其唯一的参数。

如果类装饰器返回一个值,它会使用提供的构造函数来替换类的声明。

注意  如果你要返回一个新的构造函数,你必须注意处理好原来的原型链。 在运行时的装饰器调用逻辑中 不会为你做这些。

// 类装饰器(target 就是当前类)---- 普通装饰器(无法传参)
function logClass(target: any) {
    console.log(target);
    target.prototype.apiUrl = 'dfdjfadgadgadjfad';
    target.prototype.run = function() {
        console.log('这是扩展的run方法');
    }
}

@logClass
class HttpClient {
    constructor() {

    }

    getData() {

    }
}
var http:any = new HttpClient();
console.log(http.apiUrl);
http.run();
// 类装饰器 ---- 装饰器工厂(可传参)
function logClass(params: string) {
    console.log(params);
    // target 就是当前类
    return function(target: any) {
        console.log(target);
        console.log(params);
        target.prototype.apiUrl = params;
    }
}

@logClass('http://www.baidu.com')
class HttpClient {
    constructor() {
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TypeScript装饰是一种特殊的语法,用于修改类、方法、属性或参数的行为。装饰通过在目标声明之前使用@符号来应用。装饰可以用来添加新的功能、修改行为或元数据。 装饰可以应用于类、方法、属性和参数。例如,可以使用装饰来为类添加日志记录、验证或路由等功能。 下面是一个示例,演示如何使用装饰来添加日志记录功能: ```typescriptfunction log(target: any, name: string, descriptor: PropertyDescriptor) { const originalMethod = descriptor.value; descriptor.value = function (...args: any[]) { console.log(`Calling ${name} with arguments: ${JSON.stringify(args)}`); const result = originalMethod.apply(this, args); console.log(`Method ${name} returned: ${JSON.stringify(result)}`); return result; }; return descriptor; } class MyClass { @log myMethod(arg: string) { return `Hello, ${arg}!`; } } const instance = new MyClass(); instance.myMethod("World"); ``` 在上面的示例中,我们定义了一个名为log的装饰函数。该装饰函数接收三个参数:目标对象、方法名和属性描述符。我们通过修改属性描述符的value来修改原始方法的行为,添加了日志记录的功能。 然后,我们将装饰应用于MyClass类的myMethod方法。当调用myMethod方法时,会自动触发装饰中定义的日志记录逻辑。 通过使用装饰,我们可以轻松地修改类的行为,而无需在每个方法中手动添加相同的功能。这样可以提高代码的可重用性和可维护性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值