静态初始化块是一项非常新推出的 JavaScript 功能, ECMAScript 2022,且仅在 新型浏览器。 借助静态初始化块,您可以动态设置静态字段的值, 使用涉及多条语句的逻辑。
如需创建静态初始化块,请使用 static
关键字,后跟
Curly 中的 block 语句
括号 ({}
):
class MyClass {
static {}
}
利用此模式,您可以初始化或更改 该类:
class MyClass {
static firstProperty = 'First property.';
static secondProperty;
static {
this.secondProperty = 'Second property.';
}
}
MyClass.secondProperty;
"Second property."
这些语句将在类首次初始化时进行求值,
是在 JavaScript 引擎首次评估它时,而不是在
与 constructor()
一样,它会创建相应的类:
class MyClass {
static {
console.log( "Static initialization block." );
}
constructor() {
console.log( "Constructor." );
}
}
> "Static initialization block."
const myClassInstance = new MyClass();
> "Constructor."
一个类可以包含多个静态初始化块,这些块是 将按照声明顺序与所有其他静态字段和 方法。这意味着,只有在静态初始化之前声明的字段 以下块中都有相应的块:
class MyClass {
static myNewField;
static {
this.myNewField = this.myField;
}
static myField = "My value.";
};
MyClass.myNewField;
> undefined
class MyCorrectedClass {
static myNewField;
static myField = "My value.";
static {
this.myNewField = this.myField;
}
};
MyCorrectedClass.myNewField;
> "My value."
检查您的理解情况
下列哪些表述是正确的?
一个类只能包含一个静态初始化块。
静态初始化块在类
。
在静态初始化块后声明的字段可用
内部的组件。