Issue
I created the following simple example component that adds some attributes and listener to the component DOM element using the host property of the @Component decorator. In my case [ngClass] is has no effect. Does someone know why and how to fix it?
import { Injector, Component } from "angular2/core";
import { NgClass } from "angular2/common";
import { SelectionService } from "../selection-service";
@Component({
    selector: "my-component",
    template: `<div>inner template</div>`,
    host: {
        style: "background-color: yellow", // works
        "[ngClass]": "{'selected': isSelected}", // does not work
        "(mouseover)": "mouseOver($event)", // works
        "(mouseleave)": "mouseLeave($event)", // works
    },
    directives: [NgClass],
})
export class MyComponent {
    private isSelected = false;
    constructor(private selectionService: SelectionService) {
        this.selectionService.select$.subscribe((sel: Selection) => {
            this.isSelected = sel; // has no effect on ngClass
        });
    }
    mouseOver($event) {
        console.log("mouseOver works");
    }
    mouseLeave($event) {
        console.log("mouseLeave works");
    }
}
I'm using Angular 2.0.0-beta.7.
Solution
ngClass is a directive and can't be used in host bindings. Host bindings only supports 
- property '[propName]':'expr'
- attribute '[attr.attrName]':'expr'
- event (event)="someFunction(event);otherExpr",
- style [style.width]="booleanExpr"
- class [class.className]="booleanExpr"binding.
- class [class]="expr"whereexpris a string with space separated classes
Answered By - Günter Zöchbauer
 
0 comments:
Post a Comment
Note: Only a member of this blog may post a comment.