Object.prototype.propertyIsEnumerable()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
Die Methode propertyIsEnumerable()
von Object
Instanzen gibt einen booleschen Wert zurück, der angibt, ob die angegebene Eigenschaft eine aufzählbare eigene Eigenschaft dieses Objekts ist.
Probieren Sie es aus
const object1 = {};
const array1 = [];
object1.property1 = 42;
array1[0] = 42;
console.log(object1.propertyIsEnumerable("property1"));
// Expected output: true
console.log(array1.propertyIsEnumerable(0));
// Expected output: true
console.log(array1.propertyIsEnumerable("length"));
// Expected output: false
Syntax
propertyIsEnumerable(prop)
Parameter
Rückgabewert
Ein boolescher Wert, der angibt, ob die angegebene Eigenschaft aufzählbar ist und eine eigene Eigenschaft des Objekts ist.
Beschreibung
Alle Objekte, die von Object.prototype
erben (das heißt, alle bis auf null
-Prototyp-Objekte), erben die Methode propertyIsEnumerable()
. Diese Methode bestimmt, ob die angegebene Eigenschaft, String oder Symbol, eine aufzählbare eigene Eigenschaft des Objekts ist. Falls das Objekt die angegebene Eigenschaft nicht hat, gibt diese Methode false
zurück.
Diese Methode ist äquivalent zu Object.getOwnPropertyDescriptor(obj, prop)?.enumerable ?? false
.
Beispiele
Verwendung von propertyIsEnumerable()
Das folgende Beispiel zeigt die Verwendung von propertyIsEnumerable()
auf Objekten und Arrays.
const o = {};
const a = [];
o.prop = "is enumerable";
a[0] = "is enumerable";
o.propertyIsEnumerable("prop"); // true
a.propertyIsEnumerable(0); // true
Benutzerdefinierte vs. eingebaute Objekte
Die meisten eingebauten Eigenschaften sind standardmäßig nicht aufzählbar, während benutzerdefinierte Objekteigenschaften oft aufzählbar sind, außer sie werden ausdrücklich anders festgelegt.
const a = ["is enumerable"];
a.propertyIsEnumerable(0); // true
a.propertyIsEnumerable("length"); // false
Math.propertyIsEnumerable("random"); // false
globalThis.propertyIsEnumerable("Math"); // false
Direkte vs. geerbte Eigenschaften
Nur aufzählbare eigene Eigenschaften führen dazu, dass propertyIsEnumerable()
true
zurückgibt, obwohl alle aufzählbaren Eigenschaften, einschließlich der geerbten, von der for...in
-Schleife besucht werden.
const o1 = {
enumerableInherited: "is enumerable",
};
Object.defineProperty(o1, "nonEnumerableInherited", {
value: "is non-enumerable",
enumerable: false,
});
const o2 = {
// o1 is the prototype of o2
__proto__: o1,
enumerableOwn: "is enumerable",
};
Object.defineProperty(o2, "nonEnumerableOwn", {
value: "is non-enumerable",
enumerable: false,
});
o2.propertyIsEnumerable("enumerableInherited"); // false
o2.propertyIsEnumerable("nonEnumerableInherited"); // false
o2.propertyIsEnumerable("enumerableOwn"); // true
o2.propertyIsEnumerable("nonEnumerableOwn"); // false
Test von Symbol-Eigenschaften
Symbol
-Eigenschaften werden ebenfalls von propertyIsEnumerable()
unterstützt. Beachten Sie, dass die meisten Aufzählungsmethoden nur String-Eigenschaften besuchen; die Aufzählbarkeit von Symbol-Eigenschaften ist nur bei der Verwendung von Object.assign()
oder Spread-Syntax nützlich. Weitere Informationen finden Sie unter Enumerability and ownership of properties.
const sym = Symbol("enumerable");
const sym2 = Symbol("non-enumerable");
const o = {
[sym]: "is enumerable",
};
Object.defineProperty(o, sym2, {
value: "is non-enumerable",
enumerable: false,
});
o.propertyIsEnumerable(sym); // true
o.propertyIsEnumerable(sym2); // false
Verwendung mit null-Prototyp-Objekten
Da null
-Prototyp-Objekte nicht von Object.prototype
erben, erben sie auch nicht die Methode propertyIsEnumerable()
. Sie müssen Object.prototype.propertyIsEnumerable
mit dem Objekt als this
aufrufen.
const o = {
__proto__: null,
enumerableOwn: "is enumerable",
};
o.propertyIsEnumerable("enumerableOwn"); // TypeError: o.propertyIsEnumerable is not a function
Object.prototype.propertyIsEnumerable.call(o, "enumerableOwn"); // true
Alternativ können Sie Object.getOwnPropertyDescriptor()
verwenden, das auch hilft, zwischen nicht existierenden Eigenschaften und tatsächlich nicht aufzählbaren Eigenschaften zu unterscheiden.
const o = {
__proto__: null,
enumerableOwn: "is enumerable",
};
Object.getOwnPropertyDescriptor(o, "enumerableOwn")?.enumerable; // true
Object.getOwnPropertyDescriptor(o, "nonExistent")?.enumerable; // undefined
Spezifikationen
Specification |
---|
ECMAScript® 2025 Language Specification # sec-object.prototype.propertyisenumerable |
Browser-Kompatibilität
BCD tables only load in the browser