Je suis un peu perdu, un peu.
Voir cette directive simple:
@Directive({
selector: '[myDirective]'
})
export class MyDirective {
private text: string;
private enabled: boolean;
@Input() myDirective:string;
@Input('myText')
set myText(val: string) {
this.text = val;
}
@Input('myEnabled')
set myEnabled(val: boolean) {
this.enabled = val;
}
ngOnInit() {
console.log("myDirective string: " + this.myDirective);
console.log("myText string: " + this.text);
console.log("myEnabled boolean: " + this.enabled);
}
}
si mon html ressemblera à ceci:
<div [myDirective]="myDefaultText" [myEnabled]="true" [myText]="abc"></div>
La sortie sera:
myDirective string: myDefaultText real value // good
myEnabled boolean: true // good
myText string: undefined // Why?
Si je supprime le [] de l' myText
:
<div [myDirective]="myDefaultText" [myEnabled]="true" myText="abc"></div>
La sortie sera:
myDirective string: myDefaultText real value // good
myEnabled boolean: true // good
myText string: abc // GOOD
Je peux également supprimer l' []
de myEnabled
et il sera trop de travail.
Voici donc ma confusion - quand j'ai besoin d'utiliser les crochets []
et quand pas, alors que je veux que l'utilisateur qui utilisera myDirective
n'aurez plus jamais besoin de se demander si ou si non, je pense que les crochets []
doit toujours être là. N'est-ce pas?