我正在构建前端/后端数据结构之间的简单映射。为此,我创建了一个如下所示的装饰器:
function ApiField(
apiKey: string,
setFn: (any) => any = (ret) => ret,
getFn: (any) => any = (ret) => ret
) {
return function (target: AbstractModel, propertyKey: string) {
target.apiFieldsBag = target.apiFieldsBag || {};
_.assign(
target.apiFieldsBag,
{
[propertyKey]: {
apiKey: apiKey,
setFn: setFn,
getFn: getFn
}
}
);
};
}
这就是我使用它的方式:
class AbstractCar {
@ApiField('id')
public id: string = undefined;
}
class BMW extends AbstractCar {
@ApiField('cylinders')
public cylinderCount: number;
}
class VW extends AbstractCar {
@ApiField('yearCompanyFounded')
public yearEstablished: number;
}
我看到的问题是,不是将实际对象传递给装饰器,而是它的原型:
__decorate([
ApiField('yearCompanyFounded')
], VW.prototype, "yearEstablished", void 0);
这意味着当我在装饰器中为实例分配东西时,它总是附加到原型上,这反过来意味着我只想定义VW
实例的属性也可以在AbstractCar
和BMW
类上使用(在这个例子中,这将是yearEstablished
)。这使得在两个不同的类中不可能有两个名称相同但 API 字段不同的属性。
有没有办法规避这种行为?