Dies funktioniert nur in modernen Browsern (Chrome, Firefox 4+, IE9+), aber in ECMAScript 5 können Sie alle Eigenschaften eines Objekts mit Object.getOwnPropertyNames
. Es ist nur ein wenig zusätzlicher Code erforderlich, um die geerbten Eigenschaften aus dem Prototyp zu erhalten.
// Put all the properties of an object (including inherited properties) into
// an object so they can be iterated over
function getProperties(obj, properties) {
properties = properties || {};
// Get the prototype's properties
var prototype = Object.getPrototypeOf(obj);
if (prototype !== null) {
getProperties(prototype, properties);
}
// Get obj's own properties
var names = Object.getOwnPropertyNames(obj);
for (var i = 0; i < names.length; i++) {
var name = names[i];
properties[name] = obj[name];
}
return properties;
}
function iterate(obj) {
obj = Object(obj);
var properties = getProperties(obj);
for (var name in properties) {
if (typeof properties[name] !== "function") {
console.log("property: " + name);
}
}
for (var name in properties) {
if (typeof properties[name] === "function") {
console.log("function: " + name);
}
}
}