如何将ngFor变量传递给ng-content模板。
例如,containing-component:
<ul>
<li *ngFor="let item of itemsArray">
<ng-content></ng-content>
</li>
</ul>嵌套的content-component:
<div>
<span *ngIf="item.type_one"></span>
<span *ngIf="item.type_two"></span>
</div>例如,两者都有:
<containing-component>
<content-component>
</content-component>
</containing-component>发布于 2018-08-12 19:38:39
您不能将ng-content用作动态模板。请改用ng-template
<ul>
<li *ngFor="let item of itemsArray">
<ng-container *ngTemplateOutlet="itemTemplate; context: { $implicit: item }">
</ng-container>
</li>
</ul>export class ContainingComponent {
...
@ContentChild(TemplateRef, {static: true})
@Input() itemTemplate: TemplateRef<any>;
}因此您可以将动态模板引用到containing-component中。在这种情况下,您可以在content-component上包装ng-template
<containing-component [itemTemplate]="itemTmpl">
</containing-component>
<ng-template #itemTmpl let-data>
<content-component
[item]="data">
</content-component>
</ng-template>或者使用ng-template directly
<containing-component
[itemTemplate]="itemTmpl"
[itemArray]="items">
</containing-component>
<ng-template #itemTmpl let-data>
<div>
<span *ngIf="data.type_one"></span>
<span *ngIf="data.type_two"></span>
</div>
</ng-template>https://stackoverflow.com/questions/51807192
复制相似问题