我有一个mat-tab-group (角度材料),我希望能够在mat-tab后面添加代码,包括其他组件。我正在使用ComponentFactoryResolver创建组件,但我无法通过ViewContainerRef将新组件添加到新的mat选项卡中
html
<mat-tab-group>
<mat-tab *ngFor="let tab of tabs" [label]="tab.title">
<div #test></div>
</mat-tab>
</mat-tab-group>代码隐藏
private open(type:string):void{
var tab = {title:'test'};
this.tabs.push(tab);
const factory = this.componentFactoryResolver.resolveComponentFactory(DiscountGridComponent );
//this will add it in the end of the view
const newComponentRef = this.viewContainerRef.createComponent(factory);
}发布于 2020-03-27 08:55:35
我想分享我的想法,以防对其他人有帮助:
export class DynamicTabComponent implements AfterViewInit {
public tabs = [ComponentOne, ComponentTwo];
@ViewChild('container', {read: ViewContainerRef, static: false}) public viewContainer: ViewContainerRef;
constructor(private componentFactoryResolver: ComponentFactoryResolver) {
}
public ngAfterViewInit(): void {
this.renderComponent(0);
}
public tabChange(index: number) {
setTimeout(() => {
this.renderComponent(index);
});
}
private renderComponent(index: number) {
const factory = this.componentFactoryResolver.resolveComponentFactory(this.components[index]);
this.viewContainer.createComponent(factory);
}
}模板:
<mat-tab-group (selectedIndexChange)="tabChange($event)">
<mat-tab label="Tab" *ngFor="let component of components">
<ng-template matTabContent>
<div #container></div>
</ng-template>
</mat-tab>
</mat-tab-group>发布于 2020-06-11 12:53:25
我还替换了BrowserAnimationsModule,使用了NoopAnimationsModule。
export class DynamicTabComponent implements AfterViewInit {
public tabs = [ComponentOne, ComponentTwo];
@ViewChild('container', {read: ViewContainerRef, static: false}) public
viewContainer: ViewContainerRef;
constructor(private componentFactoryResolver: ComponentFactoryResolver) {
}
public ngAfterViewInit(): void {
this.renderComponent(0);
}
public tabChange(index: number) {
setTimeout(() => {
this.renderComponent(index);
});
}
private renderComponent(index: number) {
const factory =
this.componentFactoryResolver.resolveComponentFactory(this.components[index]);
this.viewContainer.createComponent(factory);
}
}模板
<mat-tab label="Tab" *ngFor="let component of components">
<ng-template matTabContent>
<div #container></div>
</ng-template>
</mat-tab>
</mat-tab-group>模块
imports: [
CommonModule,
MaterialModuleSet,
BrowserModule,
RouterModule.forRoot(routes),
AppRoutingModule,
NoopAnimationsModule
// BrowserAnimationsModule] removed the BrowserAnimationModulehttps://stackoverflow.com/questions/52498869
复制相似问题