I've been hunting around for a clear answer to this, and most of what pops up still relates to the old (or should I say "traditional") way of defining classes using function
.
According to this SO answer,
Class properties are not supported in ES2015.
As far as I can tell, the only way to add a static variable to a class is like:
https://jsfiddle.net/abalter/fknwx3n4/
class C {
constructor(x) {
console.log("in constructor " + x);
this.x = x;
this.add(this.x);
}
add(x) {
console.log("in add " + x);
C.alist.push(x);
}
show() {
console.log("in show");
console.log(C.alist);
}
}
// MUST be done outside of actual class definition.
C.alist = [];
c1 = new C(5);
c1.show();
c2 = new C(10);
c1.show();
c2.show();
Is this the end of the story? Just seems so strange to not be able to do it INSIDE the class definition.
You could call a static function that initializes all the static members immediately after the class is defined, and then optionally delete that function. (Possibly resetting static variables would be a feature?)
This would allow you to keep all of your static variables inside the class declaration.
class C {
static init() {
C.alist = [];
}
constructor(x) {…}
add(x) {…}
show() {…}
}
C.init();
delete C.init;
Another option is to initialize static variables in the constructor, but this requires that at least one object be instantiated before the static variables can be used.
class C {
constructor(x) {
C.alist = C.alist || [];
…
}
add(x) {…}
show() {…}
}
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With