handler.set() - JavaScript | MDN
Baseline
Weitgehend verfügbar
Diese Funktion ist gut etabliert und funktioniert auf vielen Geräten und in vielen Browserversionen. Sie ist seit September 2016 browserübergreifend verfügbar.
Die handler.set() Methode ist eine Falle für die [[Set]] interne Objektmethode, die bei Operationen verwendet wird, wie zum Beispiel beim Setzen eines Eigenschaftswerts durch Eigenschafts-Zugriffsoperatoren.
Probieren Sie es aus
const monster = { eyeCount: 4 };
const handler = {
set(obj, prop, value) {
if (prop === "eyeCount" && value % 2 !== 0) {
console.log("Monsters must have an even number of eyes");
} else {
return Reflect.set(...arguments);
}
},
};
const proxy = new Proxy(monster, handler);
proxy.eyeCount = 1;
// Expected output: "Monsters must have an even number of eyes"
console.log(proxy.eyeCount);
// Expected output: 4
proxy.eyeCount = 2;
console.log(proxy.eyeCount);
// Expected output: 2
Syntax
js
new Proxy(target, {
set(target, property, value, receiver) {
}
})
Parameter
Die folgenden Parameter werden an die set() Methode übergeben. this ist an den Handler gebunden.
Rückgabewert
Die set() Methode muss einen Boolean zurückgeben, der angibt, ob die Zuweisung erfolgreich war oder nicht. Andere Werte werden in Booleans umgewandelt.
Viele Operationen, einschließlich der Nutzung von Eigenschafts-Zugriffsoperatoren im strict mode, werfen einen TypeError, wenn die [[Set]] interne Methode false zurückgibt.
Beschreibung
Abfangmöglichkeiten
Diese Falle kann folgende Operationen abfangen:
- Eigenschaftszuweisung:
proxy[foo] = barundproxy.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:
- Es kann nicht der Wert einer Eigenschaft geändert werden, um sich von dem Wert der entsprechenden Zielobjekteigenschaft zu unterscheiden, wenn die entsprechende Zielobjekteigenschaft eine nicht-schreibbare, nicht-konfigurierbare eigene Dateneigenschaft ist. Das heißt, wenn
Reflect.getOwnPropertyDescriptor()für die Eigenschaft auftargetconfigurable: false, writable: falsezurückgibt undvaluesich von demvalue-Attribut im Eigenschaftsbeschreiber vontargetunterscheidet, dann muss die Falle einen falschen Wert zurückgeben. - Es kann nicht der Wert einer Eigenschaft 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 auftargetconfigurable: false, set: undefinedzurückgibt, dann muss die Falle einen falschen Wert zurückgeben.
Beispiele
Abfangen des Setzens eines Eigenschaftswertes
Der folgende Code fängt das Setzen eines Eigenschaftswertes ab.
js
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
| Spezifikation |
|---|
| ECMAScript® 2026 Language Specification # sec-proxy-object-internal-methods-and-internal-slots-set-p-v-receiver |
Browser-Kompatibilität
Siehe auch
Help improve MDN
Erfahren Sie, wie Sie beitragen können Diese Seite wurde automatisch aus dem Englischen übersetzt.