将展平的键 - >值对转换为嵌套对象

时间:2012-06-27 22:54:46

标签: javascript parsing eval

将以下key->值对象“array”转换为正确的“JSON”样式对象的最简单方法是什么?下面的示例将输入转换为图形。

var input = {
    "graph.default.seriesColor" : ["#cccccc", "#3c3c3c"],
    "graph.default.stackSeries" : false,
    "graph.default.title.text" : "Hello!",
    "graph.default.title.show" : false,
    "graph.default.axesDefaults.show" : true,
    "graph.default.axesDefaults.min" : 17,
    "graph.default.axesDefaults.max" : 20,
};

var graph = {
    default: {
        seriesColor: ["#cccccc", "#3c3c3c"],
        stackSeries: false,

        title: {
            text: "Hello!",
            show: false
        },

        axesDefault: {
            show: true,
            min: 17,
            max: 20
        }
    }
};

我考虑使用eval,但它很快就会以递归的方式变得复杂。

1 个答案:

答案 0 :(得分:4)

出于某种原因,我真的想为你写一个函数:

function makeObj(input)
{
    var output = {};

    for(var key in input)
    {
        var nodes = key.split('.'), dest = output;

        if(nodes.length < 1)
            continue;

        for(var i = 0; i < (nodes.length - 1); ++ i)
        {
            var node = nodes[i];

            dest = (dest[node] === undefined) ?
                        (dest[node] = {}) : dest[node];
        }

        dest[nodes[nodes.length - 1]] = input[key];
    }

    return output;
}

graph = makeObj(input);

显然与eval解决方案不同,它只接受您所描述的确切格式的字符串(x.y.z)。