handler.set()
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.set()
ist eine Trap für die [[Set]]
interne Objektmethode, die von Operationen wie der Verwendung von Eigenschaftszuweisern zum Setzen des Werts einer Eigenschaft verwendet wird.
Probieren Sie es aus
Syntax
new Proxy(target, {
set(target, property, value, receiver) {
}
})
Parameter
Die folgenden Parameter werden an die Methode set()
übergeben. this
ist an den Handler gebunden.
target
-
Das Zielobjekt.
property
-
Ein String oder ein
Symbol
, das den Eigenschaftsnamen darstellt. value
-
Der neue Wert der Eigenschaft, der festgelegt werden soll.
receiver
-
Der
this
-Wert für Setter; sieheReflect.set()
. Dies ist normalerweise entweder der Proxy selbst oder ein Objekt, das vom Proxy erbt.
Rückgabewert
Die Methode set()
muss ein Boolean
zurückgeben, das angibt, ob die Zuweisung erfolgreich war oder nicht. Andere Werte werden in Booleans umgewandelt.
Viele Operationen, einschließlich der Verwendung von Eigenschaftszuweisern im Strict-Modus, werfen einen TypeError
, wenn die [[Set]]
interne Methode false
zurückgibt.
Beschreibung
Interceptionen
Diese Trap kann folgende Operationen abfangen:
- Eigenschaftszuweisung:
proxy[foo] = bar
undproxy.foo = bar
Reflect.set()
Oder jede andere Operation, die die [[Set]]
interne Methode aufruft.
Invarianten
Die [[Set]]
interne Methode des Proxys wirft einen TypeError
, wenn die Handler-Definition eine der folgenden Invarianten verletzt:
- Der Wert einer Eigenschaft kann nicht von dem Wert der entsprechenden Zielobjekteigenschaft abweichen, wenn die entsprechende Zielobjekteigenschaft eine nicht beschreibbare, nicht konfigurierbare eigene Dieneigenschaft ist. Das heißt, wenn
Reflect.getOwnPropertyDescriptor()
für die Eigenschaft auftarget
configurable: false, writable: false
zurückgibt undvalue
sich vomvalue
-Attribut im Eigenschaftsdescriptor vontarget
unterscheidet, muss die Trap einen falschen Wert zurückgeben. - Der Wert einer Eigenschaft kann nicht gesetzt werden, wenn die entsprechende Zielobjekteigenschaft eine nicht konfigurierbare eigene Accessor-Eigenschaft ist, die einen undefinierten Setter hat. Das heißt, wenn
Reflect.getOwnPropertyDescriptor()
für die Eigenschaft auftarget
configurable: false, set: undefined
zurückgibt, muss die Trap einen falschen Wert zurückgeben.
Beispiele
Trap beim Setzen eines Eigenschaftswerts
Der folgende Code fängt das Setzen eines Eigenschaftswerts ab.
const p = new Proxy(
{},
{
set(target, prop, value, receiver) {
target[prop] = value;
console.log(`property set: ${prop} = ${value}`);
return true;
},
},
);
console.log("a" in p); // false
p.a = 10; // "property set: a = 10"
console.log("a" in p); // true
console.log(p.a); // 10
Spezifikationen
Specification |
---|
ECMAScript Language Specification # sec-proxy-object-internal-methods-and-internal-slots-set-p-v-receiver |
Browser-Kompatibilität
BCD tables only load in the browser