TypeScript 装饰器顺序

import 'reflect-metadata';

function showData(target: typeof User) {
  for (let key in target.prototype) {
    const data = Reflect.getMetadata('data', target.prototype, key);
    console.log(data);
    // 这里能拿到数据,说明方法上的装饰器优先于类装饰器
  }
}

function setData(msg: string) {
  return function (target: User, key: string) {
    Reflect.defineMetadata('data', msg, target, key);
  }
}

@showData
class User {
  @Reflect.metadata('data', 'name')
  getName() { }

  @setData('age') // 跟上面的一样的作用
  getAge() {}
}

 

上一篇:Vue3解决问题之Proxy在Vue中的作用


下一篇:TypeScript reflect-metadata 库