Доступ к вложенному атрибуту n-го уровня в объекте javascript с помощью переменной Dynami c - PullRequest
0 голосов
/ 25 мая 2020

Предположим, у меня есть объект

const aggs = {
      cat.id: {
        terms: { field: 'cat.id', size: 10 },
        aggs: { cat.label: {field: 'cat.label', size: 5} }
      }
    }

В переменной Dynami c у меня есть

const key = '[cat.id].aggs'

Теперь мне нужно получить доступ к атрибуту aggs внутри объекта aggs с помощью Dynami c переменная

aggs[key]

, которая не работает. Как я могу получить доступ к вложенным атрибутам динамически? Очевидно, что доступ к нему напрямую, как это работает

aggs['cat.id'].aggs

1 Ответ

1 голос
/ 25 мая 2020

Вы можете использовать обычные решения , но со специальным c регулярным выражением, которое должным образом работает с скобками, позволяя использовать точки в именах свойств:

const pathToArray = path => 
  Array.from(path.matchAll(/\[(.*?)\]|[^.[]+/g) || [], 
             ([prop, inbrackets]) => inbrackets || prop);

function deepGet(obj, path, defaultVal = null) {
  for (let prop of pathToArray(path)) {
    if (!(prop in obj)) return defaultVal;
    obj = obj[prop];
  }
  return obj;
}

function deepSet(obj, path, value) {
  let arr = pathToArray(path);
  arr.slice(0, -1).reduce((a, c, i) =>
    Object(a[c]) === a[c] ? a[c] :
    a[c] = Math.abs(path[i + 1]) >> 0 === +path[i + 1] ? [] : {},
    obj)[arr[arr.length - 1]] = value;
  return obj;
}

// Your example:
const aggs = {"cat.id": {terms: {field: "cat.id",size: 10},aggs: {"cat.label": {field: "cat.label",size: 5}}}};
const key = "[cat.id].aggs";

console.log(deepGet(aggs, key));
deepSet(aggs, key, "hello");
console.log(deepGet(aggs, key));
...