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
new Proxy(target, {
has(target, property) {
}
})
Parameter
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:
- Den
in
-Operator:foo in proxy
with
-Überprüfung:with(proxy) { (foo); }
Reflect.has()
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 auftarget
zurückgibt, muss die Traptrue
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
auftarget
zurückgibt undReflect.getOwnPropertyDescriptor()
einen Eigenschaftsbeschreiber für die Eigenschaft auftarget
zurückgibt, muss die Traptrue
zurückgeben.
Beispiele
Den in-Operator abfangen
Der folgende Code fängt den in
-Operator ab.
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.
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