继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

【十月打卡】第62天 TypeScript(18)

康遇
关注TA
已关注
手记 76
粉丝 3
获赞 9

类的方法修饰器

方法修饰器的用法

参数:

  • target:当前方法所在的对象
  • key:当前方法的名称
  • descriptor:当前方法的描述符

原型上的方法的target就是原型

function getNameDecoration(target: any, key: string, descriptor: any) {
  console.log(target === Test.prototype);  // true
}

class Test {
  constructor(private name: string) {}

  @getNameDecoration
  getName() {
    return this.name;
  }
}

类的方法的target就是类本身

function getNameDecoration(target: any, key: string, descriptor: any) {
  console.log(target === Test);   // true
}

class Test {
  constructor(private name: string) {}

  @getNameDecoration
  static getName() {
    return this.name;
  }
}

属性描述符descriptor

descriptor.value可以修改属性的值

function getNameDecoration(target: any, key: string, descriptor: any) {
  descriptor.value = () => {
    return 'abc';
  };
}

class Test {
  constructor(private name: string) {}

  @getNameDecoration
  getName() {
    return this.name;
  }
}

const test = new Test('hello');

console.log(test.getName());  // abc

如果装饰器属性描述符descriptor.writable = false; 那么该属性可读不可写
如下类的原型和实例都不可以重写方法

function getNameDecoration(target: any, key: string, descriptor: any) {
  descriptor.writable = false;
}

class Test {
  constructor(private name: string) {}

  @getNameDecoration
  getName() {
    return this.name;
  }
}

const test = new Test('hello');
test.getName = () => {   
  return '123';
};
打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP