handler.ownKeys()

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 handler.ownKeys()-Methode ist ein Trap für die [[OwnPropertyKeys]] interne Methode des Objekts, die von Operationen wie Object.keys(), Reflect.ownKeys() usw. verwendet wird.

Probieren Sie es aus

const monster = {
  _age: 111,
  [Symbol("secret")]: "I am scared!",
  eyeCount: 4,
};

const handler = {
  ownKeys(target) {
    return Reflect.ownKeys(target);
  },
};

const proxy = new Proxy(monster, handler);

for (const key of Object.keys(proxy)) {
  console.log(key);
  // Expected output: "_age"
  // Expected output: "eyeCount"
}

Syntax

js
new Proxy(target, {
  ownKeys(target) {
  }
})

Parameter

Folgender Parameter wird an die Methode ownKeys() übergeben. this ist an den Handler gebunden.

target

Das Zielobjekt.

Rückgabewert

Die Methode ownKeys() muss ein array-ähnliches Objekt zurückgeben, bei dem jedes Element entweder ein String oder ein Symbol ist, wobei keine doppelten Einträge vorkommen.

Beschreibung

Interceptions

Dieser Trap kann diese Operationen abfangen:

Oder jede andere Operation, die die [[OwnPropertyKeys]] interne Methode aufruft.

Invarianten

Die [[OwnPropertyKeys]]-Methode des Proxys löst einen TypeError aus, wenn die Handler-Definition eine der folgenden Invarianten verletzt:

  • Das Ergebnis ist ein Object.
  • Die Liste der Schlüssel enthält keine doppelten Werte.
  • Der Typ jedes Schlüssels ist entweder ein String oder ein Symbol.
  • Die Ergebnisliste muss die Schlüssel aller nicht konfigurierbaren eigenen Eigenschaften des Zielobjekts enthalten. Das heißt, für alle Schlüssel, die durch Reflect.ownKeys() auf dem Zielobjekt zurückgegeben werden, muss der Schlüssel enthalten sein, wenn der Schlüssel durch Reflect.getOwnPropertyDescriptor() configurable: false meldet.
  • Wenn das Zielobjekt nicht erweiterbar ist, muss die Ergebnisliste alle Schlüssel der eigenen Eigenschaften des Zielobjekts und keine anderen Werte enthalten. Das heißt, wenn Reflect.isExtensible() auf target false zurückgibt, muss die Ergebnisliste die gleichen Werte wie das Ergebnis von Reflect.ownKeys() auf target enthalten.

Beispiele

Abfangen von getOwnPropertyNames

Der folgende Code fängt Object.getOwnPropertyNames() ab.

js
const p = new Proxy(
  {},
  {
    ownKeys(target) {
      console.log("called");
      return ["a", "b", "c"];
    },
  },
);

console.log(Object.getOwnPropertyNames(p));
// "called"
// [ 'a', 'b', 'c' ]

Der folgende Code verletzt eine Invariante.

js
const obj = {};
Object.defineProperty(obj, "a", {
  configurable: false,
  enumerable: true,
  value: 10,
});

const p = new Proxy(obj, {
  ownKeys(target) {
    return [123, 12.5, true, false, undefined, null, {}, []];
  },
});

console.log(Object.getOwnPropertyNames(p));

// TypeError: proxy [[OwnPropertyKeys]] must return an array
// with only string and symbol elements

Spezifikationen

Specification
ECMAScript® 2026 Language Specification
# sec-proxy-object-internal-methods-and-internal-slots-ownpropertykeys

Browser-Kompatibilität

Siehe auch