Nullish-Zuweisungsoperator (??=)
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since September 2020.
Der Nullish-Zuweisungsoperator (??=
), auch bekannt als logischer Nullish-Zuweisungsoperator, wertet nur den rechten Operand aus und weist diesen dem linken Operand zu, wenn der linke Operand nullish (null
oder undefined
) ist.
Probieren Sie es aus
const a = { duration: 50 }; a.speed ??= 25; console.log(a.speed); // Expected output: 25 a.duration ??= 10; console.log(a.duration); // Expected output: 50
Syntax
x ??= y
Beschreibung
Die Nullish-Zuweisung short-circuited, was bedeutet, dass x ??= y
gleichbedeutend ist mit x ?? (x = y)
, außer dass der Ausdruck x
nur einmal ausgewertet wird.
Es wird keine Zuweisung durchgeführt, wenn die linke Seite nicht nullish ist, aufgrund des Short-Circuitings des Nullish-Zusammenführungsoperators. Zum Beispiel wirft das folgende Beispiel keinen Fehler, obwohl x
eine const
ist:
const x = 1; x ??= 2;
Auch das folgende Beispiel würde den Setter nicht auslösen:
const x = { get value() { return 1; }, set value(v) { console.log("Setter called"); }, }; x.value ??= 2;
Tatsächlich wird y
überhaupt nicht ausgewertet, wenn x
nicht nullish ist.
const x = 1; x ??= console.log("y evaluated"); // Logs nothing
Beispiele
Verwendung des Nullish-Zuweisungsoperators
Sie können den Nullish-Zuweisungsoperator verwenden, um Standardwerte auf Objekteigenschaften anzuwenden. Im Vergleich zur Verwendung von Destrukturierung und Standardwerten wird durch ??=
der Standardwert auch angewendet, wenn die Eigenschaft den Wert null
hat.
function config(options) { options.duration ??= 100; options.speed ??= 25; return options; } config({ duration: 125 }); // { duration: 125, speed: 25 } config({}); // { duration: 100, speed: 25 }
Spezifikationen
Specification |
---|
ECMAScript® 2026 Language Specification # sec-assignment-operators |