Baseline Widely available
Die statische Methode Reflect.setPrototypeOf()
ist ähnlich wie Object.setPrototypeOf()
, gibt jedoch einen Boolean
zurück. Sie setzt das Prototype (d.h. die interne [[Prototype]]
-Eigenschaft) eines angegebenen Objekts.
const object1 = {};
console.log(Reflect.setPrototypeOf(object1, Object.prototype));
// Expected output: true
console.log(Reflect.setPrototypeOf(object1, null));
// Expected output: true
const object2 = {};
console.log(Reflect.setPrototypeOf(Object.freeze(object2), null));
// Expected output: false
Syntax
Reflect.setPrototypeOf(target, prototype)
Parameter
target
Das Zielobjekt, dessen Prototype gesetzt werden soll.
prototype
Das neue Prototype des Objekts (ein Objekt oder null
).
Ein Boolean
, der angibt, ob das Prototype erfolgreich gesetzt wurde oder nicht.
TypeError
Ausgelöst, wenn target
kein Objekt ist oder prototype
weder ein Objekt noch null
ist.
Reflect.setPrototypeOf()
bietet die reflektive Semantik, um das Prototype eines Objekts zu setzen. Auf sehr niedrigem Niveau gibt das Setzen des Prototypes einen Boolean zurück (wie im Fall des Proxy-Handlers). Object.setPrototypeOf()
bietet eine nahezu gleiche Semantik, wirft jedoch einen TypeError
, wenn der Status false
ist (die Operation war erfolglos), während Reflect.setPrototypeOf()
den Status direkt zurückgibt.
Reflect.setPrototypeOf()
ruft die [[SetPrototypeOf]]
interne Objektsmethode von target
auf.
Reflect.setPrototypeOf({}, Object.prototype); // true
// It can change an object's [[Prototype]] to null.
Reflect.setPrototypeOf({}, null); // true
// Returns false if target is not extensible.
Reflect.setPrototypeOf(Object.freeze({}), null); // false
// Returns false if it cause a prototype chain cycle.
const target = {};
const proto = Object.create(target);
Reflect.setPrototypeOf(target, proto); // false
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