* ng对于ng-content Angular的元素

时间:2017-09-18 18:00:00

标签: javascript angular typescript components angular2-ngcontent

我想知道是否可以创建某些元素的迭代。我需要为ng-content的每个元素使用不同的css类,所以我需要对ng-content的每个元素进行循环。有可能吗?

现在我将一个参数传递给子元素来枚举他,但我想在没有数字的情况下这样做。这是我的代码:

<sys-tab [tabs]="['Principal', 'Complementar']">
  <sys-tab-content [num]="1">
    <sys-panel header="Dados Gerais">
      <sys-input-text header="Nome" tam="1"></sys-input-text>

      <sys-input-mask header="CNPJ"></sys-input-mask>
      <sys-input-mask header="CNES"></sys-input-mask>
      <sys-input-mask header="Telefone"></sys-input-mask>

      <sys-input-text header="Email"></sys-input-text>
    </sys-panel>
  </sys-tab-content>
  <sys-tab-content [num]="2">
    <sys-input-text header="Email"></sys-input-text>
  </sys-tab-content>
</sys-tab>

正如你所看到的那样,对于孩子我传递了数字,所以我可以识别谁是他,但我想创建一个循环到ng-coontent所以我可以为每个“sys-tab-content”添加一个不同的类“

2 个答案:

答案 0 :(得分:1)

带有动态ngTemplate的简单列表示例

app.component.ts

import { Component } from '@angular/core';

@Component({
  selector: 'my-app',
  templateUrl: './app.component.html'
})
export class AppComponent  {
  items = [ { name: 'abc' }, { name: 'cdf' }, { name: 'fgh' } ];
}

app.component.html

<nu-list [itemTpl]="itemTpl" [items]="items"></nu-list>
<ng-template let-item #itemTpl> 
    <h1>{{item.name}}</h1>
</ng-template>

list.component.ts

import { Component, Input } from '@angular/core';

@Component({
  selector: 'nu-list',
  templateUrl: './list.component.html'
})
export class ListComponent  {

  @Input() itemTpl;
  @Input() items;

}

list.component.html

<ng-container *ngFor="let item of items">
  <ng-container *ngTemplateOutlet="itemTpl; context: {$implicit: item}"></ng-container>
</ng-container>

示例链接:https://stackblitz.com/edit/angular-list-ngtemplateoutlet

答案 1 :(得分:0)

有两种方法可以添加“ngFor”或通过孩子进行迭代。

一个是通过翻译:另一个是通过检查父组件的ViewChildren。