handler.has()

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 Methode handler.has() ist eine Trap für die [[HasProperty]] interne Objektmethode, die von Operationen wie dem in-Operator verwendet wird.

Probieren Sie es aus

Syntax

js
new Proxy(target, {
  has(target, property) {
  }
})

Parameter

Die folgenden Parameter werden der has()-Methode übergeben. this ist an den Handler gebunden.

target

Das Zielobjekt.

property

Ein String oder Symbol, der den Eigenschaftsnamen darstellt.

Rückgabewert

Die has()-Methode muss einen Boolean zurückgeben, der anzeigt, ob die Eigenschaft existiert oder nicht. Andere Werte werden in Booleans umgewandelt.

Beschreibung

Interzeptionen

Diese Trap kann folgende Operationen abfangen:

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

Invarianten

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

  • Eine Eigenschaft kann nicht als nicht existent gemeldet werden, wenn sie als nicht konfigurierbares eigenes Attribut des Zielobjekts existiert. Das heißt, wenn Reflect.getOwnPropertyDescriptor() configurable: false für die Eigenschaft auf target zurückgibt, muss die Trap true zurückgeben.
  • Eine Eigenschaft kann nicht als nicht existent gemeldet werden, wenn sie als eigene Eigenschaft des Zielobjekts existiert und das Zielobjekt nicht erweiterbar ist. Das heißt, wenn Reflect.isExtensible() false auf target zurückgibt und Reflect.getOwnPropertyDescriptor() einen Eigenschaftsbeschreiber für die Eigenschaft auf target zurückgibt, muss die Trap true zurückgeben.

Beispiele

Den in-Operator abfangen

Der folgende Code fängt den in-Operator ab.

js
const p = new Proxy(
  {},
  {
    has(target, prop) {
      console.log(`called: ${prop}`);
      return true;
    },
  },
);

console.log("a" in p);
// "called: a"
// true

Der folgende Code verletzt eine Invariante.

js
const obj = { a: 10 };
Object.preventExtensions(obj);

const p = new Proxy(obj, {
  has(target, prop) {
    return false;
  },
});

"a" in p; // TypeError is thrown

Spezifikationen

Specification
ECMAScript Language Specification
# sec-proxy-object-internal-methods-and-internal-slots-hasproperty-p

Browser-Kompatibilität

BCD tables only load in the browser

Siehe auch