是否有一种通用的方法将嵌套对象“压缩”到一个级别:
var myObj = {
a: "hello",
b: {
c: "world"
}
}
compress(myObj) == {
a: "hello",
b_c: "world"
}
我猜这里可能涉及到一些递归,但我想我不需要在这里重新发明轮子... !?
是否有一种通用的方法将嵌套对象“压缩”到一个级别:
var myObj = {
a: "hello",
b: {
c: "world"
}
}
compress(myObj) == {
a: "hello",
b_c: "world"
}
我猜这里可能涉及到一些递归,但我想我不需要在这里重新发明轮子... !?
function flatten(obj, includePrototype, into, prefix) {
into = into || {};
prefix = prefix || "";
for (var k in obj) {
if (includePrototype || obj.hasOwnProperty(k)) {
var prop = obj[k];
if (prop && typeof prop === "object" &&
!(prop instanceof Date || prop instanceof RegExp)) {
flatten(prop, includePrototype, into, prefix + k + "_");
}
else {
into[prefix + k] = prop;
}
}
}
return into;
}
通过将第二个参数传递为true
,您可以包含继承的成员。
但是需要注意以下几点:
递归对象不起作用。例如:
var o = { a: "foo" };
o.b = o;
flatten(o);
该函数会递归执行,直到抛出异常。
和ruquay的答案一样,它像访问普通对象属性一样提取数组元素。如果您想保持数组完整性,请将“|| prop instanceof Array
”添加到异常中。
如果您在不同窗口或框架中调用此函数的对象,则日期和正则表达式将不包括在内,因为instanceof
将无法正常工作。您可以通过像这样替换为默认的toString方法来解决这个问题:
Object.prototype.toString.call(prop) === "[object Date]"
Object.prototype.toString.call(prop) === "[object RegExp]"
Object.prototype.toString.call(prop) === "[object Array]"
以下是一份快速的代码,但要注意,它不能用于数组和null值(因为它们的typeof返回值为“object”)。
var flatten = function(obj, prefix) {
if(typeof prefix === "undefined") {
prefix = "";
}
var copy = {};
for (var p in obj) {
if(obj.hasOwnProperty(p)) {
if(typeof obj[p] === "object") {
var tmp = flatten(obj[p], p + "_");
for(var q in tmp) {
if(tmp.hasOwnProperty(q)) {
copy[prefix + q] = tmp[q];
}
}
}
else {
copy[prefix + p] = obj[p];
}
}
}
return copy;
}
var myObj = {
a: "level 1",
b: {
a: "level 2",
b: {
a: "level 3",
b: "level 3"
}
}
}
var flattened = flatten(myObj);
includePrototype
,因为我不需要它):flatten = (obj, into = {}, prefix = '', sep = '_') ->
for own key, prop of obj
if typeof prop is 'object' and prop not instanceof Date and prop not instanceof RegExp
flatten prop, into, prefix + key + sep, sep
else
into[prefix + key] = prop
into
unflatten = (obj, into = {}, sep = '_') ->
for own key, prop of obj
subKeys = key.split sep
sub = into
sub = (sub[subKey] or= {}) for subKey in subKeys[...-1]
sub[subKeys.pop()] = prop
into