Can ngClass use ternary operator in Angular 2?
Solution 1:
Yes. What you wrote works:
<div [ngClass]="varA === varB ? 'css-class-1' : 'css-class-2'">
Plunker
The result of the expression on the the right-hand side has to evaluate to one of the following:
- a string of space-delimited CSS class names (this is what your expression returns)
- an Array of CSS class names
- an Object, with CSS class names as keys, and booleans as values
Maybe you had some other error in your code?
Solution 2:
<div [ngClass]="{'css-class-1':varA === varB, 'css-class-2': varA !== varB}">
See also https://angular.io/api/common/NgClass
Solution 3:
You can try the followings.....
For ternary operator use:
[ngClass]="condition1==condition2?'class-1':'class-2'"
For multiple condition use:
[ngClass]="{'class-1':condition1==condition2, 'class-2': condition3==condition4}"
thnks...