类里方法的装饰器

类的方法的装饰器
  • 方法的装饰器的执行时间也是在类定义之后,立即对类的方法进行装饰修改
  • 方法的装饰器接受3个参数 target、key、descriptor
  • 普通方法 target 对应的是类的prototype, key对应的是装饰的方法的名字
  • 静态方法(static) target 对应的是类的构造函数, key对应的是装饰的方法的名字
function getNameDecorator(target: any, key: string,descriptor: PropertyDescriptor) {
  // console.log(target,key);
};

class Test{
  name: string;
  constructor(name: string) {
    this.name = name;
  }
  @getNameDecorator
  getName() {
    return this.name;
  }
  // static getName() {
  //   return '123';
  // }
}

// const test = new Test('yang');
// console.log(test.getName());
descriptor参数就是对方法的 PropertyDescriptor属性(value,enumerable,configurable,writable )做一些编辑
class Test{
  name: string;
  constructor(name: string) {
    this.name = name;
  }
  @getNameDecorator
  getName() {
    return this.name;
  }
}

// 默认情况下 descriptor的writable为true,也就是可以被修改。false时是只读的
const test = new Test('yang');
test.getName = () => {
  return '123';
}

console.log(test.getName());  // 123
  • 当我们修改descriptor的writable为false的时候,就不能去改写getName 方法了,否则会报错
  • 当然了,就算是descriptor的writable为false的时候,我们也可以通过对descriptor的value进行变更。从而达到对原来的方法的变更。因为value就是属性的值,而此时value的值就是getName方法。
function getNameDecorator(target: any, key: string,descriptor:PropertyDescriptor) {
  // console.log(target,key);
  descriptor.writable = false;
  descriptor.value = function () {
    return 'decorator'
  }
};

class Test{
  name: string;
  constructor(name: string) {
    this.name = name;
  }
  @getNameDecorator
  getName() {
    return this.name;
  }
}

const test = new Test('yang');
console.log(test.getName());  // decorator
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容