2

我想使用 ng-container 从 ngFor 中调用 ng-template

我的列表是一个数组,并且有一个对象列表。对象的一个​​属性是标题 - 在 ng 模板中可以看到。

html:

<ul>

    <li *ngFor='let item of list;let i = index'>

        <ng-container *ngTemplateOutlet="itemTemplate;context:item"></ng-container>

    </li>

</ul>

<ng-template #itemTemplate let-item="item">
    <p>{{ item?.title }}</p>
</ng-template>

注意:问题是 let-item 似乎未定义或为空对象。这很奇怪,因为我把它传进去了。

4

3 回答 3

5

您对 的使用templateOutletContext略有错误。

您可以使用$implicit上下文的密钥,然后将其绑定到您的模板,如下所示:

<ul>
  <li *ngFor="let item of list">
    <ng-container *ngTemplateOutlet="itemTemplate; context: { $implicit: item }">
    </ng-container>
  </li>
</ul>
<ng-template #itemTemplate let-item>
    <p>{{ item?.title }}</p>
</ng-template>

或使用命名键:

<ul>
  <li *ngFor="let item of list">
    <ng-container *ngTemplateOutlet="itemTemplate; context: { item: item }">
    </ng-container>
  </li>
</ul>
<ng-template #itemTemplate let-item="item">
    <p>{{ item?.title }}</p>
</ng-template>
于 2017-11-28T10:36:17.163 回答
0

首先你的元素必须在 *ngFor 的范围内。就像你想重复一个

标签内的标签。那么代码将是

<div *ngFor="item in items">
  <p>{{item}}</p>
</div>

同样在你的情况下必须在里面

  • 标签

    <ul>
    
        <li *ngFor='let item of list;let i = index'>
    
            <ng-container *ngTemplateOutlet="itemTemplate;context:item"></ng-container>
    <ng-template #itemTemplate let-item="item">
        <p>{{ item?.title }}</p>
    </ng-template>
    
        </li>
    
    </ul>
    
  • 于 2017-11-28T10:25:40.970 回答
    0
    <ul>
      <li *ngFor="let i of list">
        <ng-container *ngTemplateOutlet="itemTemplate; context: { i: i }">
        </ng-container>
      </li>
    </ul>
    <ng-template #itemTemplate let-item="i">
        <p>{{ i?.title }}</p>
    </ng-template>
    
    于 2017-11-28T10:39:45.417 回答