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

时间:2019-06-21 15:44:12

标签: angular

我有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>'},
  ];

有人可以帮我吗

2 个答案:

答案 0 :(得分:0)

尝试一下:

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

答案 1 :(得分:0)

为什么不使用@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());