handler.getOwnPropertyDescriptor()
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 handler.getOwnPropertyDescriptor()-Methode ist eine Trap für die [[GetOwnProperty]] objektinternen Methode, die von Operationen wie Object.getOwnPropertyDescriptor() verwendet wird.
Probieren Sie es aus
const monster = {
eyeCount: 4,
};
const handler = {
getOwnPropertyDescriptor(target, prop) {
console.log(`called: ${prop}`);
// Expected output: "called: eyeCount"
return { configurable: true, enumerable: true, value: 5 };
},
};
const proxy = new Proxy(monster, handler);
console.log(Object.getOwnPropertyDescriptor(proxy, "eyeCount").value);
// Expected output: 5
Syntax
new Proxy(target, {
getOwnPropertyDescriptor(target, property) {
}
})
Parameter
Die folgenden Parameter werden an die getOwnPropertyDescriptor()-Methode übergeben. this ist an den Handler gebunden.
Rückgabewert
Die getOwnPropertyDescriptor()-Methode muss ein Objekt oder undefined zurückgeben, das den Eigenschaftsdescriptor darstellt. Fehlende Attribute werden auf die gleiche Weise normalisiert wie bei Object.defineProperty().
Beschreibung
>Abfangvorgänge
Diese Trap kann folgende Vorgänge abfangen:
Oder jede andere Operation, die die [[GetOwnProperty]] interne Methode aufruft.
Invarianten
Die [[GetOwnProperty]]-interne Methode des Proxys wirft einen TypeError, wenn die Handler-Definition eine der folgenden Invarianten verletzt:
- Das Ergebnis muss entweder ein
Objectoderundefinedsein. - Eine Eigenschaft kann nicht als nicht existent gemeldet werden, wenn sie als nicht konfigurierbare eigene Eigenschaft des Zielobjekts existiert. Das heißt, wenn
Reflect.getOwnPropertyDescriptor()configurable: falsefür die Eigenschaft auftargetzurückgibt, darf die Trap nichtundefinedzurückgeben. - Eine Eigenschaft kann nicht als nicht existent gemeldet werden, wenn sie als eigene Eigenschaft eines nicht erweiterbaren Zielobjekts existiert. Das heißt, wenn
Reflect.isExtensible()falsefür das Zielobjekt zurückgibt, darf die Trap nichtundefinedzurückgeben. - Eine Eigenschaft kann nicht als existent gemeldet werden, wenn sie nicht als eigene Eigenschaft des Zielobjekts existiert und das Zielobjekt nicht erweiterbar ist. Das heißt, wenn
Reflect.isExtensible()falsefür das Zielobjekt zurückgibt undReflect.getOwnPropertyDescriptor()undefinedfür die Eigenschaft auftargetzurückgibt, muss die Trapundefinedzurückgeben. - Eine Eigenschaft kann nicht als nicht konfigurierbar gemeldet werden, es sei denn, sie existiert als nicht konfigurierbare eigene Eigenschaft des Zielobjekts. Das heißt, wenn
Reflect.getOwnPropertyDescriptor()undefinedoderconfigurable: truefür die Eigenschaft auftargetzurückgibt, darf die Trap nichtconfigurable: falsezurückgeben. - Eine Eigenschaft kann nicht als nicht konfigurierbar und nicht beschreibbar gemeldet werden, es sei denn, sie existiert als nicht konfigurierbare, nicht beschreibbare eigene Eigenschaft des Zielobjekts. Das heißt, zusätzlich zur vorherigen Invariante, wenn
Reflect.getOwnPropertyDescriptor()configurable: false, writable: truefür die Eigenschaft auftargetzurückgibt, darf die Trap nichtconfigurable: false, writable: falsezurückgeben. - Wenn eine Eigenschaft eine entsprechende Eigenschaft auf dem Zielobjekt hat, muss der Descriptor der Zielobjekteigenschaft mit
descriptorkompatibel sein. Das heißt, angenommen,targetist ein gewöhnliches Objekt, dann darfObject.defineProperty(target, property, resultObject)keinen Fehler auslösen. Die Referenz vonObject.defineProperty()enthält mehr Informationen, aber zusammengefasst, wenn die Zieleigenschaft nicht konfigurierbar ist, muss Folgendes gelten:configurable,enumerable,getundsetmüssen wie im Original sein.writablemuss auch aufgrund der vorherigen Invariante das Original sein.- die Eigenschaft muss als Daten- oder Accessor-Eigenschaft bleiben
- das
value-Attribut kann nur geändert werden, wennwritabletrueist
Beispiele
>Abfangen von getOwnPropertyDescriptor
Der folgende Code fängt Object.getOwnPropertyDescriptor() ab.
const p = new Proxy(
{ a: 20 },
{
getOwnPropertyDescriptor(target, prop) {
console.log(`called: ${prop}`);
return { configurable: true, enumerable: true, value: 10 };
},
},
);
console.log(Object.getOwnPropertyDescriptor(p, "a").value);
// "called: a"
// 10
Der folgende Code verletzt eine Invariante.
const obj = { a: 10 };
Object.preventExtensions(obj);
const p = new Proxy(obj, {
getOwnPropertyDescriptor(target, prop) {
return undefined;
},
});
Object.getOwnPropertyDescriptor(p, "a"); // TypeError is thrown
Spezifikationen
| Specification |
|---|
| ECMAScript® 2026 Language Specification> # sec-proxy-object-internal-methods-and-internal-slots-getownproperty-p> |
Browser-Kompatibilität
Loading…