TS之装饰器

装饰器

装饰器是一种特殊类型的声明,它能够被附加到类声明,方法,属性或参数上,可以修改类的行为。
通俗的讲,装饰器就是一个方法,可以注入到类、方法、属性、参数上来扩展类、方法、属性、参数的功能。
常见的装饰器有:普通装饰器(无法传参)、装饰器工厂(可传参)

装饰器类型

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

类装饰器

  • 类装饰器在类声明之前被声明(紧靠着类声明);
  • 类装饰器应用于类构造函数,可以用来监视、修改或替换类定义;
  • 类的构造函数将作为唯一参数传递给装饰器;
  • 如果类装饰器返回一个值,它会使用返回的构造函数替换原来的类声明;
// 类装饰器(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() {
   

    }

    getData() {
   

    }
}
var http: any = new HttpClient();
console.log(http.apiUrl);
// 类装饰器重载构造函数
// 类装饰器表达式会在运行时当作函数被调用,类的构造函数作为其唯一的参数
// 如果类装饰器返回一个值,它会使用提供的构造函数来替换类的声明
function logClass(target: any) {
   
    console.log(target);
    return class extends target {
   
        apiUrl: any = '我是修改后的apiUrl';
        getData() {
   
            this.apiUrl += '----'
            console.log(this
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值