handler.defineProperty()
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.defineProperty()
ist eine Trap für die [[DefineOwnProperty]]
-interne Objektmethode, die von Operationen wie Object.defineProperty()
verwendet wird.
Probieren Sie es aus
const handler1 = {
defineProperty(target, key, descriptor) {
invariant(key, "define");
return true;
},
};
function invariant(key, action) {
if (key[0] === "_") {
throw new Error(`Invalid attempt to ${action} private "${key}" property`);
}
}
const monster1 = {};
const proxy1 = new Proxy(monster1, handler1);
console.log((proxy1._secret = "easily scared"));
// Expected output: Error: Invalid attempt to define private "_secret" property
Syntax
new Proxy(target, {
defineProperty(target, property, descriptor) {
}
})
Parameter
Die folgenden Parameter werden an die Methode defineProperty()
übergeben. this
ist an den Handler gebunden.
target
-
Das Zielobjekt.
property
-
Ein String oder ein
Symbol
, der den Eigenschaftsnamen darstellt. descriptor
-
Der Descriptor für die zu definierende oder zu modifizierende Eigenschaft.
Rückgabewert
Die Methode defineProperty()
muss einen Boolean
zurückgeben, der angibt, ob die Eigenschaft erfolgreich definiert wurde oder nicht. Andere Werte werden in Booleans umgewandelt.
Viele Operationen, einschließlich Object.defineProperty()
und Object.defineProperties()
, werfen einen TypeError
, wenn die interne Methode [[DefineOwnProperty]]
false
zurückgibt.
Beschreibung
Abfangvorgänge
Diese Trap kann folgende Operationen abfangen:
Oder jede andere Operation, die die [[DefineOwnProperty]]
-interne Methode aufruft.
Invarianten
Die interne Methode [[DefineOwnProperty]]
des Proxy-Objekts wirft einen TypeError
, wenn die Handler-Definition eine der folgenden Invarianten verletzt:
- Eine Eigenschaft kann nicht hinzugefügt werden, wenn das Zielobjekt nicht erweiterbar ist. Das bedeutet, wenn
Reflect.isExtensible()
auftarget
false
zurückgibt undReflect.getOwnPropertyDescriptor()
für die Eigenschaft auftarget
undefined
zurückgibt, muss die Trap einen falsy-Wert zurückgeben. - Eine Eigenschaft kann nicht nicht-konfigurierbar sein, es sei denn, es existiert eine entsprechende nicht-konfigurierbare eigene Eigenschaft des Zielobjekts. Das bedeutet, wenn
Reflect.getOwnPropertyDescriptor()
für die Eigenschaft auftarget
undefined
oderconfigurable: true
zurückgibt unddescriptor.configurable
false
ist, muss die Trap einen falsy-Wert zurückgeben. - Eine nicht-konfigurierbare Eigenschaft kann nicht nicht-beschreibbar sein, es sei denn, es existiert eine entsprechende nicht-konfigurierbare, nicht-beschreibbare eigene Eigenschaft des Zielobjekts. Das bedeutet, wenn
Reflect.getOwnPropertyDescriptor()
für die Eigenschaft auftarget
configurable: false, writable: true
zurückgibt unddescriptor.writable
false
ist, muss die Trap einen falsy-Wert zurückgeben. - Wenn eine Eigenschaft eine entsprechende Eigenschaft im Zielobjekt hat, muss der Deskriptor der Zieleigenschaft mit
descriptor
kompatibel sein. Das bedeutet, angenommentarget
ist ein gewöhnliches Objekt undObject.defineProperty(target, property, descriptor)
würde einen Fehler werfen, dann muss die Trap einen falsy-Wert zurückgeben. Die ReferenzObject.defineProperty()
enthält weitere Informationen, aber zusammenfassend gilt: Wenn die Zieleigenschaft nicht konfigurierbar ist, müssen die folgenden Kriterien erfüllt sein:configurable
,enumerable
,get
undset
dürfen nicht geändert werden- die Eigenschaft darf nicht zwischen Daten und Zugriffswerten geändert werden
- das Attribut
writable
kann nur vontrue
zufalse
geändert werden - das Attribut
value
kann nur geändert werden, wennwritable
true
ist
Beispiele
Abfangen von defineProperty
Der folgende Code fängt Object.defineProperty()
ab.
const p = new Proxy(
{},
{
defineProperty(target, prop, descriptor) {
console.log(`called: ${prop}`);
return true;
},
},
);
const desc = { configurable: true, enumerable: true, value: 10 };
Object.defineProperty(p, "a", desc); // "called: a"
Beim Aufruf von Object.defineProperty()
oder Reflect.defineProperty()
hat der descriptor
, der an die defineProperty()
-Trap übergeben wird, eine Einschränkung – nur die folgenden Eigenschaften können verwendet werden (nicht-standardisierte Eigenschaften werden ignoriert):
enumerable
configurable
writable
value
get
set
const p = new Proxy(
{},
{
defineProperty(target, prop, descriptor) {
console.log(descriptor);
return Reflect.defineProperty(target, prop, descriptor);
},
},
);
Object.defineProperty(p, "name", {
value: "proxy",
type: "custom",
}); // { value: 'proxy' }
Spezifikationen
Specification |
---|
ECMAScript® 2026 Language Specification # sec-proxy-object-internal-methods-and-internal-slots-defineownproperty-p-desc |