如何过滤对象的所有属性的对象?

How can I filter an object of all properties that are objects?

我正在尝试制作一个只包含非对象属性的对象的副本。但是子对象会随之复制。

var testObject = {
  stringProperty: "hi",
  intProperty: 4,
  objectProperty: {},
  nullProperty: null
};

console.log(removeChildObjects(testObject));

function removeChildObjects(object) {
  var keys = Object.keys(object);
  var newObject = {};
  keys.forEach(function(key) {
    console.log(key, object[key], typeof object[key]);
    if (typeof object[key] != "object") {
      newObject[key] = object[key];
    }
  });
  return object;
}

也可以在这里查看 https://jsfiddle.net/uss94sc3/1/

尝试用 return newObject; 替换 return object;。它会更好用!

https://jsfiddle.net/w3urvpjq/

你return传递的是同一个对象:

return object;

你应该returnnewObject

return newObject;

如果要严格过滤对象属性(保留 nullundefined 属性),则不能依赖损坏的 typeof 一元运算符。

typeof null
// "object"

您可以将代码更改为:

function removeChildObjects(object) {
    var keys = Object.keys(object);
    var newObject = {};
    keys.forEach(function(key) {
        if (typeof object[key] != "object" || object[key] == null) {
            newObject[key] = object[key];
        }
    });
    return newObject;
}

或用下划线更简洁:

function removeChildObjects(object) {
    return _.omit(object, _.isObject);
}

你可以试试这个

var testObject = {
                  stringProperty: "hi",
                     intProperty: 4,
                  objectProperty: {},
                    nullProperty: null
                 };
var filterPrimitive = o => Object.keys(o).reduce((p,k) => {typeof o[k] != "object" && (p[k] = o[k]); return p},{});

document.write("<pre>" + JSON.stringify(filterPrimitive(testObject),null,2) + "</pre>");