如何在ng-template中动态添加模板参考ID

我有json对象,其中包含一些html字符串。需要创建具有唯一参考变量的多个ng-template。 

<div *ngFor="let el of ElementList">
    <ng-template #el.id>
      <div [innerHtml]="el.html"></div>
    </ng-template> 
   </div>

这是我的ElementList数组 

ElementList = [
    {id: 'h1', html: '<h1>sample heading</h1>'},
    {id: 'h2', html: '<h2>sample heading</h2>'},
    {id: 'h3', html: '<h3>sample heading</h3>'},
  ];

解决方法:

使用@ViewChildren

<div *ngFor="let el of ElementList">
  <ng-template #elem>
      <div [innerHtml]="el.html"></div>
    </ng-template> 
</div>

在组件类中,通过ViewChildren访问模板引用变量,就像这样 

 @ViewChildren(TemplateRef) elem : QueryList<TemplateRef<any>>;

现在可以访问模板了。 

console.log(this.elem.toArray());