为了账号安全,请及时绑定邮箱和手机立即绑定

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

标签:
Typescript

类的方法修饰器

方法修饰器的用法

参数:

  • 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';
};
点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消