Reflect.setPrototypeOf()

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 statische Methode Reflect.setPrototypeOf() ist ähnlich wie Object.setPrototypeOf(), gibt jedoch einen Boolean zurück. Sie setzt das Prototyp (d. h. die interne [[Prototype]]-Eigenschaft) eines angegebenen Objekts.

Probieren Sie es aus

Syntax

js
Reflect.setPrototypeOf(target, prototype)

Parameter

target

Das Zielobjekt, dessen Prototyp eingestellt werden soll.

prototype

Der neue Prototyp des Objekts (ein Objekt oder null).

Rückgabewert

Ein Boolean, der angibt, ob der Prototyp erfolgreich gesetzt wurde oder nicht.

Ausnahmen

TypeError

Wird ausgelöst, wenn target kein Objekt ist oder wenn prototype weder ein Objekt noch null ist.

Beschreibung

Reflect.setPrototypeOf() bietet die reflektierende Semantik zum Setzen des Prototyps eines Objekts. Auf sehr niedrigem Niveau gibt das Setzen des Prototyps einen booleschen Wert zurück (wie es auch beim Proxy-Handler der Fall ist). Object.setPrototypeOf() bietet nahezu dieselbe Semantik, löst jedoch einen TypeError aus, wenn der Status false ist (die Operation war nicht erfolgreich), während Reflect.setPrototypeOf() den Status direkt zurückgibt.

Reflect.setPrototypeOf() ruft die [[SetPrototypeOf]] interne Objektmethode von target auf.

Beispiele

Verwendung von Reflect.setPrototypeOf()

js
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

Specification
ECMAScript Language Specification
# sec-reflect.setprototypeof

Browser-Kompatibilität

BCD tables only load in the browser

Siehe auch