Files
30-seconds-of-code/snippets/js/s/deep-get-object-value.md
Angelos Chalaris 9d032ce05e Rename js snippets
2023-05-19 20:23:47 +03:00

863 B

title, type, language, tags, cover, dateModified
title type language tags cover dateModified
Get nested value in object based on array of keys snippet javascript
object
mask-quiet 2020-10-19T18:51:03+03:00

Gets the target value in a nested JSON object, based on the keys array.

  • Compare the keys you want in the nested JSON object as an Array.
  • Use Array.prototype.reduce() to get the values in the nested JSON object one by one.
  • If the key exists in the object, return the target value, otherwise return null.
const deepGet = (obj, keys) =>
  keys.reduce(
    (xs, x) => (xs && xs[x] !== null && xs[x] !== undefined ? xs[x] : null),
    obj
  );
let index = 2;
const data = {
  foo: {
    foz: [1, 2, 3],
    bar: {
      baz: ['a', 'b', 'c']
    }
  }
};
deepGet(data, ['foo', 'foz', index]); // get 3
deepGet(data, ['foo', 'bar', 'baz', 8, 'foz']); // null