4

目前正在学习 Angular5 课程,并且在对该主题进行了一段时间的研究之后,我仍然不完全理解以下内容:

代码:

App.component.html:

      <app-server-element 
      *ngFor="let serverElement of serverElements"
      [element]="serverElement"
       ></app-server-element>

App.component.ts:

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

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  serverElements = [{type: 'server', name:'Testserver',content:'just a test!'},
                    {type: 'server', name:'Testserver',content:'just a test!'}
];  
   }

服务器-element.component.html:

  <p>
    <strong *ngIf="element.type === 'server'" style="color: red">
{{ element.content }}</strong>
    <em *ngIf="element.type === 'blueprint'">{{ element.content }}</em>
  </p>

服务器-element.component.ts:

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

@Component({
  selector: 'app-server-element',
  templateUrl: './server-element.component.html',
  styleUrls: ['./server-element.component.css']
})
export class ServerElementComponent implements OnInit {
 @Input() element: {type:string, name:string, content:string};
}

问题:

我有点困惑这部分的作用:

  *ngFor="let serverElement of serverElements"
  [element]="serverElement"

在我目前的理解中,它是一个循环遍历 serverElementsArray 的所有元素的 for 循环。但是[element]="serverElement"具体做什么呢?

4

2 回答 2

9

您对遍历所有元素的循环是完全正确的serverElementsArray

使用[element]=...您绑定组件的输入。继续阅读... :-)

注意它在哪里循环 -app-server-element组件。我假设这个组件负责打印我们的服务器详细信息。

但是你必须以某种方式为它提供它应该打印出来的服务器。这就是[element]=...玩的地方

注意 的@Input() element部分ServerElementComponent。这定义了该组件接受一些输入值。

因此,使用[element]=...您将单个 serverElement 绑定到被@Input调用element 的 in ServerElementComponent。循环中的每个项目都会有多个ServerElementComponents。

于 2017-11-12T23:37:16.257 回答
0

使用@Input 方法,您只能在父子组件之间进行通信。并且很难管理父子组件的层次结构。所以考虑 Rxjs 事件发射器,它允许与兄弟组件通信,也使用这里引用的公共服务

于 2018-01-26T17:20:06.207 回答