如何将表达式作为Angular2中的输入传递给组件?

时间:2016-10-11 09:22:43

标签: angular angular2-components

我需要将表达式传递给将在组件模板中进行评估的组件。

例如,组件:

@Component({
  selector: 'app-my-component',
  ...
})
export class MyComponent {
  @Input items: MyClass;
  @Input expression: String;
  ...
}

使用组件的模板:

<div *ngFor="let item of items">
  {{expression}}
</div>

MyComponent的用法:

<app-my-component [items]="listOfItems" [expression]="'[item.id] item.name'">
</app-my-component>

因为会有多个输入,所以我想避免使用TemplateRef。

1 个答案:

答案 0 :(得分:18)

也许其中一个选项可以帮助您:

1)使用NgFor指令的ngForTemplate输入属性:

<强>组件

@Component({
  selector: 'app-my-component',
  template: `
  <div *ngFor="let item of items template: itemTemplate"></div>`
})
export class MyComponent {
  @Input() items: any;
  @ContentChild(TemplateRef) itemTemplate: TemplateRef<any>;
}

<强>父

<app-my-component [items]="listOfItems">
  <ng-template let-item>[{{item.id}}] {{item.name}}</ng-template>
</app-my-component>

<强> Plunker

2)使用NgTemplateOutlet指令

<强>组件

@Component({
  selector: 'app-my-component',
  template: `
  <div *ngFor="let item of items">
    <ng-template [ngTemplateOutlet]="itemTemplate" [ngTemplateOutletContext]="{ $implicit: item }"></ng-template>
  </div>`
})
export class MyComponent {
  @Input() items: any;
  @ContentChild(TemplateRef) itemTemplate: TemplateRef<any>;
}

保持不变:

<app-my-component [items]="listOfItems">
  <ng-template let-item>[{{item.id}}] {{item.name}}</ng-template>
</app-my-component>

<强> Plunker

这样在<ng-template let-item>...</ng-template>内可以使用所需的表达式