можно ли и как можно сделать следующее.
Мне нужно в компоненты внедрить пару общих значений (одно поле и один метод).
Я хочу сделать декоратор и применить его везде, где нужно. В тестовом исполнении это выглядит примерно так:
function ExtendedRouting<T extends { new (...args: any[]): {} }>(
target: T
) {
return class extends target {
private service = TaxonomyService.get();
public routePrefix: string = this.service.getRoutePrefix();
public getFullPath(path: string): string[] {
return this.service.getRoutePathWithPrefix(path);
}
};
}
@Component({
selector: 'app-currency-units',
templateUrl: './currency-units.component.html',
styleUrls: ['./currency-units.component.scss']
})
@ExtendedRouting
export class CurrencyUnitsComponent implements OnInit, OnDestroy {
…
Вопрос: как потом заставить компилятор поверить в то, что добавленные свойства действительно существуют, чтобы можно было к ним оращаться как в .ts файле, так и в темплейте?
а чем обычный абстрактный класс вам не понравился ?
Интерфейс объявить мб, и сделать компонент implements MyInterface
декораторы не меняют тип, так что скорее всего никак
Ну то есть по сути поля в рантайме доступны будут, но тайпскрипту этого не объяснить, так получается?
тайпскрипту можно объяснить что угодно, но придется явное приведение типа делать. и в шаблоне не получится, если $any не делаь
Абидна. Это стирает всё удобство. Придётся через наследование.
или через провайдер
Обсуждают сегодня