ng如果设置颜色?

Edu*_*yan 7 typescript angular

我有这个json:

[{
    "nodename": "Main application Server",
    "enabled": true
},
 {
    "nodename": "Main Server",
    "enabled": false
}]
Run Code Online (Sandbox Code Playgroud)

并使用ngFor在我的模板中显示此数据:

<div class="row" *ngFor="let list of lists">
        <div class="col-md-12 col-xs-12">
            <div class="panel panel-primary">
                <div class="panel-heading">
                    <h2 class="panel-title text-center">Server: {{ list.nodename }}, {{ list.enabled }}</h2>
                </div>
            </div>   
         </div>
<div>  
Run Code Online (Sandbox Code Playgroud)

而现在,我会在我panel-primary的模板中设置不同的颜色:如果"enabled": true,设置为绿色,如果"enabled": false设置为红色.这是怎么回事?用ngIf=...?或者是其他东西?

Thi*_*ier 13

您可以利用ngStyle指令:

<div class="panel panel-primary"
    [ngStyle]="{'background-color': list.enabled? 'green' : 'red'}">
Run Code Online (Sandbox Code Playgroud)

或ngClass:

<div class="panel panel-primary"
    [ngClass]="{greenClass: list.enabled, redClass: !list.enabled}">
Run Code Online (Sandbox Code Playgroud)

在组件中使用以下样式:

@Component({
  (...)
  styles: [
    `
      .greenClass { background-color: green }
      .redClass { background-color: red }
    `
  ]
})
Run Code Online (Sandbox Code Playgroud)