Reflect.deleteProperty()
Baseline
Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since September 2016.
Die Reflect.deleteProperty() statische Methode ist wie der delete Operator, aber als Funktion. Sie löscht eine Eigenschaft aus einem Objekt.
Probieren Sie es aus
const object = {
foo: 42,
};
Reflect.deleteProperty(object, "foo");
console.log(object.foo);
// Expected output: undefined
const array = [1, 2, 3, 4, 5];
Reflect.deleteProperty(array, "3");
console.log(array);
// Expected output: Array [1, 2, 3, <1 empty slot>, 5]
Syntax
Reflect.deleteProperty(target, propertyKey)
Parameter
target-
Das Zielobjekt, bei dem die Eigenschaft gelöscht werden soll.
propertyKey-
Der Name der zu löschenden Eigenschaft.
Rückgabewert
Ein boolescher Wert, der angibt, ob die Eigenschaft erfolgreich gelöscht wurde oder nicht.
Ausnahmen
TypeError-
Wird ausgelöst, wenn
targetkein Objekt ist.
Beschreibung
Reflect.deleteProperty() bietet die reflektierte Semantik des delete Operators. Das heißt, Reflect.deleteProperty(target, propertyKey) ist semantisch äquivalent zu:
delete target.propertyKey;
Auf sehr niedrigem Niveau gibt das Löschen einer Eigenschaft einen booleschen Wert zurück (wie es bei dem Proxy-Handler der Fall ist). Reflect.deleteProperty() gibt direkt den Status zurück, während delete in strengem Modus einen TypeError auslösen würde, wenn der Status false ist. Im nicht strengen Modus haben delete und Reflect.deleteProperty() dasselbe Verhalten.
Reflect.deleteProperty() ruft die [[Delete]] interne Methode eines Objekts von target auf.
Beispiele
>Verwendung von Reflect.deleteProperty()
const obj = { x: 1, y: 2 };
Reflect.deleteProperty(obj, "x"); // true
console.log(obj); // { y: 2 }
const arr = [1, 2, 3, 4, 5];
Reflect.deleteProperty(arr, "3"); // true
console.log(arr); // [1, 2, 3, <1 empty slot>, 5]
// Returns true if no such property exists
Reflect.deleteProperty({}, "foo"); // true
// Returns false if a property is unconfigurable
Reflect.deleteProperty(Object.freeze({ foo: 1 }), "foo"); // false
Spezifikationen
| Specification |
|---|
| ECMAScript® 2026 Language Specification> # sec-reflect.deleteproperty> |
Browser-Kompatibilität
Loading…