如何在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());
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值