I want to inherit parent's template using component's inheritance in Angular.
Intro
I have some basic component (let's call it ParentComponent) and several childs of this component (Child1Component and Child2Component). I want to put default behavior in the ParentComponent and then just setup/extend this behavior in children components. ParentComponent template already contains all the needed things, so I want children components to use this template by default.
First variant of implementation (does not work, Error: No template specified for component Child1Component):
@Component({
    selector: 'app-parent',
    templateUrl: './app-parent.component.html',
    styleUrls: ['./app-parent.component.scss']
})
export class ParentComponent {
}
@Component({
    selector: 'app-child1'
})
export class Child1Component extends ParentComponent {
}
@Component({
    selector: 'app-child2'
})
export class Child2Component extends ParentComponent {
}
I found that I can set templateUrl and styleUrls of children to parent's template, but it will work only if ViewEncapsulation of children is set to None.
Second variant (it works, but I don't like it):
@Component({
    selector: 'app-parent',
    templateUrl: './app-parent.component.html',
    styleUrls: ['./app-parent.component.scss']
})
export class ParentComponent {
}
@Component({
    selector: 'app-child1',
    templateUrl: '../parent/app-parent.component.html',
    styleUrls: ['../parent/app-parent.component.scss'],
    encapsulation: ViewEncapsulation.None
})
export class Child1Component extends ParentComponent {
}
@Component({
    selector: 'app-child2',
    templateUrl: '../parent/app-parent.component.html',
    styleUrls: ['../parent/app-parent.component.scss'],
    encapsulation: ViewEncapsulation.None
})
export class Child2Component extends ParentComponent {
}
I don't like this solution cause of
Can you please suggest me better solution for this task?
@Input() and @Output() give a child component a way to communicate with its parent component. @Input() lets a parent component update data in the child component. Conversely, @Output() lets the child send data to a parent component.
To let Angular know that a property in a child component or directive can receive its value from its parent component we must use the @Input() decorator in the said child. The @Input() decorator allows data to be input into the child component from a parent component.
Second approach is the only possible way, because there are rules for decorator inheritance, see https://github.com/angular/angular/issues/11606.
@Component decorator can not be partially inherited, it is all or nothing.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With