class Customer {
constructor(firstName, lastName) {
this.firstName = firstName;
}
get firstName() {
return this._firstName;
}
set firstName(value) {
this._firstName = value;
}
}
/* @HACK: Last time we use var, I promise! */
var customer = new Customer();
customer.firstName = 'Foo';
console.log(customer.firstName); // Foo
Ne les utilisez pas.
L'implémentation de propriétés peut s'avérer pratique dans certains cas extrêmes tels que l'intégration d'une librairie "legacy", mocking, décoration pour "type checking" etc...
Autrement, cela introduit surtout de l'ambiguité dans le code.
Qui pourrait imaginer que le code suivant puisse lever une exception ?
var customer = new Customer();
element.textContent = customer.name;
Ou pire encore :
/* @HACK: Do not remove this useless line as it initializes
* the user eagerly instead of running it lazily. */
request.user;
Toute ressemblance avec du code existant est fortuite.
En l'absence de notion de "class fields", il est recommandé d'initialiser toutes les attributs dans le constructeur. Autrement, il est difficile de déterminer les attributs d'une classe et les attributs présents sur une instance dépendront alors des méthodes appelées.
En attendant la notion de qui sera probablement bientôt introduite en ECMAScript 2018 , la notion de visibilité private se base sur la convention de nommage qui consiste à préfixer la propriété ou la méthode par le caractère underscore : _