It's easy to bind CSS classes to elements in your Angular 2 templates. You provide a class name with <^>class.className<^> between brackets in your templates and then an expression on the right that should evaluate to true or false to determine if the class should be applied. Here's how you would bind a single class for example:

				
					
&lt;div [class.active]="isActive"&gt;

  ...

&lt;/div&gt;

				
			

NgClass for multiple classes

class illustration for: NgClass for multiple classes

When multiple classes should potentially be added, the <^>NgClass<^> directive comes in really handy. NgClass should receive an object with class names as keys and expressions that evaluate to true or false as values:

				
					
&lt;div [ngClass]="myClasses"&gt;

  ...

&lt;/div&gt;

				
			

And then myClasses would be a property in the component that contains an object that looks like this:

				
					
myClasses = {

  important: this.isImportant,

  inactive: !this.isActive,

  saved: this.isSaved,

  long: this.name.length &gt; 6

}

				
			

Of course the object can also be the return value of a method:

				
					
&lt;div [ngClass]="setMyClasses()"&gt;

  ...

&lt;/div&gt;

				
			

In the associated component class

				
					
setMyClasses() {

  let classes = {

    important: this.isImportant,

    inactive: !this.isActive,

    saved: this.isSaved,

    long: this.name.length &gt; 6

  };

  return classes;

}