Как использовать ngClass с условными выражениями - PullRequest
1 голос
/ 17 апреля 2019

Цвет моего элемента значка мата должен изменяться динамически.

<mat-icon class="temperature icon" svgIcon="thermometer-alert" matTooltip = {{temp_tooltip}}
          aria-label="Icon that displays a tooltip when focused or hovered over"
          [ngClass]= "{
            'safe' : 23 <= temp_tooltip <= 24.5,
            'alarm_lowside' : 21 <= temp_tooltip < 23,
            'alarm_highside' : 24.5 < temp_tooltip <= 26, 
            'critical_lowside' : temp_tooltip < 21,
            'critical_highside' : temp_tooltip > 26
           }" >
        </mat-icon>

Значение temp_tooltip связано в component.ts

, а css имеет цветовой стиль

.safe {
 color: green
}

.alarm_lowside {
    color: yellow
}

.alarm_highside {
    color: yellow
}

.critical_lowside {
    color: red
}

.critical_highside{
    color: red
}

он отлично работает с классами crit_lowside и crit_highside, но не для других классов.Как исправить.Это способ определения ngClass это правильно?

Ответы [ 2 ]

2 голосов
/ 17 апреля 2019

23 <= temp_tooltip <= 24.5 не является правильным выражением в javascript / typcript.

Вы должны найти другой способ сформулировать это условие, например 23 <= temp_tooltip && temp_tooltip <= 24.5

1 голос
/ 17 апреля 2019

Правильный синтаксис будет такой:

 [ngClass]= "{
        'safe' : temp_tooltip >= 23 && temp_tooltip <= 24.5,
        'alarm_lowside' : temp_tooltip >= 21 && temp_tooltip < 23,
        'alarm_highside' : temp_tooltip > 24.5 && temp_tooltip <= 26, 
        'critical_lowside' : temp_tooltip < 21,
        'critical_highside' : temp_tooltip > 26
   }"
...