Baseline Widely available
Die statische Methode Object.isExtensible()
bestimmt, ob ein Objekt erweiterbar ist (ob ihm neue Eigenschaften hinzugefügt werden können).
const object1 = {};
console.log(Object.isExtensible(object1));
// Expected output: true
Object.preventExtensions(object1);
console.log(Object.isExtensible(object1));
// Expected output: false
Syntax Parameter
obj
Das zu überprüfende Objekt.
Ein Boolean
, der angibt, ob das gegebene Objekt erweiterbar ist oder nicht.
Objekte sind standardmäÃig erweiterbar: ihnen können neue Eigenschaften hinzugefügt werden und ihr [[Prototype]]
kann neu zugewiesen werden. Ein Objekt kann mit einer der Methoden Object.preventExtensions()
, Object.seal()
, Object.freeze()
oder Reflect.preventExtensions()
als nicht erweiterbar gekennzeichnet werden.
// New objects are extensible.
const empty = {};
Object.isExtensible(empty); // true
// They can be made un-extensible
Object.preventExtensions(empty);
Object.isExtensible(empty); // false
// Sealed objects are by definition non-extensible.
const sealed = Object.seal({});
Object.isExtensible(sealed); // false
// Frozen objects are also by definition non-extensible.
const frozen = Object.freeze({});
Object.isExtensible(frozen); // false
Nicht-Objekt-Argument
In ES5 löst die Methode einen TypeError
aus, wenn das Argument kein Objekt (ein primitiver Wert) ist. In ES2015 wird false
zurückgegeben, ohne dass ein Fehler auftritt, wenn ein Nicht-Objekt-Argument übergeben wird, da primitive Werte per Definition unveränderlich sind.
Object.isExtensible(1);
// TypeError: 1 is not an object (ES5 code)
Object.isExtensible(1);
// false (ES2015 code)
Spezifikationen Browser-Kompatibilität Siehe auch
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4