我是 Angular2 的新手,有两个问题:
1. 我想知道为什么这样是正确的:
<p myHighlight [color1]='color' defaultColor="violet">Highlight me!</p>
并且这些不是
<p myHighlight color1='color' defaultColor="violet">Highlight me!</p>
<p myHighlight [color1]='color' [defaultColor]="violet">Highlight me!</p>
为什么我只能把一个属性放在括号中,另一个不用。
2. 如何在我的代码中使用@Input()指令而没有别名。是否可以对多个属性起作用? 以下是我的指令代码:
import { Input, Directive, ElementRef, HostListener } from '@angular/core';
@Directive({
selector: '[myHighlight]'
})
export class myDir {
constructor(private el: ElementRef) {
}
@Input('color1') color: string;//for ts code 'color' for html code 'myHighlight' i.e template component
@Input('defaultColor') defaultColor: string;
@HostListener('mouseenter') onMouseEnter() {
this.highlight(this.color || this.defaultColor);
}
@HostListener('mouseleave') onMouseLeave() {
this.highlight(null);
}
private highlight(color: string) {
this.el.nativeElement.style.backgroundColor = color;
}
}
我的HTML代码:
<div>
<input type="radio" name="clr" (click)="color='lightgreen'">Green
<input type="radio" name="clr" (click)="color='yellow'">Yellow
<input type="radio" name="clr" (click)="color='cyan'">Cyan
</div>
<p myHighlight [color1]='color' [defaultColor]='violet'>Highlight me!</p>