Как создать вложенный объект, учитывая массив ключей

Дано такое массив:

var level = ["a", "b", "x"];

Выход должен быть:

{
    "a": {
        "b": {
            "x": {
            }
        }
    }
}

Я попробовал это:

var level = ["a", "b", "x"];
var o = {};
for (var c = 0, len = level.length; c < len; c +=1 ) { 
    var part = level[c]; 
    o[part] = {}; // how to remember the last part?
}

Как я могу запомнить последнюю часть и добавить следующий уровень?

Ответы

Ответ 1

Вы можете использовать проверку, если уровень существует, и назначить только объект, если он не установлен.

function addLevels(levels, object) {
    levels.reduce((o, l) => o[l] = o[l] || {}, object);
}

var object = {};

addLevels(["a", "b", "x"], object);
addLevels(["a", "d", "z"], object);

console.log(object);

Ответ 2

Вы можете использовать метод reduceRight, передав функцию arrow качестве аргумента.

var level = ["a", "b", "x"];
let result = level.reduceRight((obj, elem) => ({[elem]: obj}), {});
console.log(result);

Ответ 3

Простейшей настройкой было бы переназначить o на каждой итерации:

var level = ["a", "b", "x"];
var o = {};
var initialO = o;
for (var c = 0, len = level.length; c < len; c +=1 ) { 
  var part = level[c];
  o[part] = {};
  o = o[part];
}
console.log(initialO);

Ответ 4

Этот, я думаю, проще всего, если вы напишете его в функциональном стиле.

var level = ["a", "b", "x"];
var o = {};
level.reduce(function (obj, key) {
    o[key] = {};
    return o[key];
}, o);

Ответ 5

Или с рекурсивной функцией

const level = ["a", "b", "x"];
const f = (i) => i === level.length ? {} : {[level[i]]: f(i+1)};
console.log(f(0));