Object() Konstruktor

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.

Der Object()-Konstruktor wandelt die Eingabe in ein Objekt um. Sein Verhalten hängt vom Typ der Eingabe ab.

Syntax

js
new Object()
new Object(value)

Object()
Object(value)

Hinweis:>Object() kann mit oder ohne new aufgerufen werden, jedoch manchmal mit unterschiedlichen Effekten. Siehe Rückgabewert.

Parameter

value Optional

Ein beliebiger Wert.

Rückgabewert

Wenn der Object()-Konstruktor selbst aufgerufen oder konstruiert wird, ist sein Rückgabewert ein Objekt:

  • Wenn der Wert null oder undefined ist, wird ein leeres Objekt erstellt und zurückgegeben.
  • Wenn der Wert bereits ein Objekt ist, wird der Wert zurückgegeben.
  • Andernfalls wird ein Objekt eines Typs zurückgegeben, das dem gegebenen Wert entspricht. Zum Beispiel führt die Übergabe eines primitiven BigInt zu einem BigInt-Wrapper-Objekt.

Wenn Object() konstruiert wird, aber new.target nicht der Object-Konstruktor selbst ist, ist das Verhalten etwas anders — es initialisiert ein neues Objekt mit new.target.prototype als Prototyp. Jeder Argumentwert wird ignoriert. Dies kann zum Beispiel passieren, wenn Object() implizit über super() im Konstruktor einer Klasse aufgerufen wird, die von Object erbt. In diesem Fall, selbst wenn Sie eine Zahl an super() übergeben, wird der this Wert im Inneren des Konstruktors keine Number-Instanz.

Beispiele

Ein neues Objekt erstellen

js
const o = new Object();
o.foo = 42;

console.log(o);
// { foo: 42 }

Verwendung von Object mit undefined und null Typen

Die folgenden Beispiele speichern ein leeres Object-Objekt in o:

js
const o = new Object();
js
const o = new Object(undefined);
js
const o = new Object(null);

Wrapper-Objekte für BigInt und Symbol erhalten

Die Konstruktoren BigInt() und Symbol() werfen einen Fehler, wenn sie mit new aufgerufen werden, um den häufigen Fehler zu verhindern, ein Wrapper-Objekt anstelle des primitiven Wertes zu erstellen. Der einzige Weg, um ein Wrapper-Objekt für diese Typen zu erstellen, ist, Object() mit ihnen aufzurufen:

js
const numberObj = new Number(1);
console.log(typeof numberObj); // "object"

const bigintObj = Object(1n);
console.log(typeof bigintObj); // "object"

const symbolObj = Object(Symbol("foo"));
console.log(typeof symbolObj); // "object"

Spezifikationen

Specification
ECMAScript® 2026 Language Specification
# sec-object-constructor

Browser-Kompatibilität

Siehe auch