Javascript get full index of nested object Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern) Data science time! April 2019 and salary with experience The Ask Question Wizard is Live!How do JavaScript closures work?What is the most efficient way to deep clone an object in JavaScript?How do I remove a property from a JavaScript object?How do you get a timestamp in JavaScript?Which equals operator (== vs ===) should be used in JavaScript comparisons?How do I include a JavaScript file in another JavaScript file?Get the current URL with JavaScript?What does “use strict” do in JavaScript, and what is the reasoning behind it?How to check whether a string contains a substring in JavaScript?How do I remove a particular element from an array in JavaScript?

What came first? Venom as the movie or as the song?

Why did Bronn offer to be Tyrion Lannister's champion in trial by combat?

Im stuck and having trouble with ¬P ∨ Q Prove: P → Q

Providing direct feedback to a product salesperson

Assertions In A Mock Callout Test

Raising a bilingual kid. When should we introduce the majority language?

Like totally amazing interchangeable sister outfit accessory swapping or whatever

How was Lagrange appointed professor of mathematics so early?

When does Bran Stark remember Jamie pushing him?

Sorting the characters in a utf-16 string in java

2 sample t test for sample sizes - 30,000 and 150,000

Is there a verb for listening stealthily?

How to know or convert AREA, PERIMETER units in QGIS

What is the difference between 准时 and 按时?

Does using the Inspiration rules for character defects encourage My Guy Syndrome?

What is the evidence that custom checks in Northern Ireland are going to result in violence?

What is the ongoing value of the Kanban board to the developers as opposed to management

What were wait-states, and why was it only an issue for PCs?

A journey... into the MIND

Suing a Police Officer Instead of the Police Department

Can a Wizard take the Magic Initiate feat and select spells from the Wizard list?

Has a Nobel Peace laureate ever been accused of war crimes?

Putting Ant-Man on house arrest

Help Recreating a Table



Javascript get full index of nested object



Announcing the arrival of Valued Associate #679: Cesar Manara
Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern)
Data science time! April 2019 and salary with experience
The Ask Question Wizard is Live!How do JavaScript closures work?What is the most efficient way to deep clone an object in JavaScript?How do I remove a property from a JavaScript object?How do you get a timestamp in JavaScript?Which equals operator (== vs ===) should be used in JavaScript comparisons?How do I include a JavaScript file in another JavaScript file?Get the current URL with JavaScript?What does “use strict” do in JavaScript, and what is the reasoning behind it?How to check whether a string contains a substring in JavaScript?How do I remove a particular element from an array in JavaScript?



.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty height:90px;width:728px;box-sizing:border-box;








0















const items = [
id: 'item1',
children: [
id: 'item1-1',
children: [
id: 'item1-1-1' ,
id: 'item1-1-2' ,
id: 'item1-1-3'
children: [
id: 'item1-1-3-1'
]
,
]
,
id: 'item1-2',
children: [
id: 'item1-2-1'
]

]
,
id: 'item2'
]


What I want to is like below,



function getFullDepthOfObject()
...


getFullIndexOfObject('item1') =====> return '1'
getFullIndexOfObject('item1-2') =====> return '1-2'
getFullIndexOfObject('item1-1-1') =====> return '1-1-1'
getFullIndexOfObject('item1-1-2') =====> return '1-1-2'
getFullIndexOfObject('item2') ===> return '2'


I have struggled with this too much time, But I couldn't make it. I think I should stack each of parent index, But I don't know how to get its parent. Is there a way to do this?



Not parse of id string. Each id has randomic string. The id like item1-2 is for easier demonstration.



I think my way is too verbose...
I tried like ...



// Get Full Index of item1-1


// First, get the target's depth.
var depth = 0;

function getDepthOfId(object, id)
var level;
if (object.id === id) return 1;
object.children && object.children.some(o => level = getDepthOfId(o, id));
return level && level + 1;


depth = getDepthOfId(items[0], 'item1-1');
console.log('depth === ', depth)


// Then, iterate recursively with length of depth.

var indexStacks = [];


function getNestedIndexOfId(obj, id, index)
if (obj.id === id)
indexStacks = [index, ...indexStacks]
return index;


if (obj.children)
depth++;
obj.children.map((child, i) =>
getNestedIndexOfId(child, id, i)
)



// I can get the inner index, but I can't get its parent id.
// I don't know how to this..

function getParentId(obj, id)
// ...?
var parentId;
return parentId;


for(var i=0; i<depth; i++)
getNestedIndexOfId('...')



// full path will be
indexStacks.join('-')









share|improve this question



















  • 1





    Wouldn't this suffice? getFullIndexOfObject = index =>index.replace('item', ''); This looks like this is result you are looking for

    – Miroslav Glamuzina
    Mar 9 at 3:15












  • @MiroslavGlamuzina The item's id is for easier understood, my code has id with uuid

    – Juntae
    Mar 9 at 3:19











  • What does the real code look like? Because even if it is but it is still in the format item__UUID__ this would still be valid.

    – Miroslav Glamuzina
    Mar 9 at 3:30

















0















const items = [
id: 'item1',
children: [
id: 'item1-1',
children: [
id: 'item1-1-1' ,
id: 'item1-1-2' ,
id: 'item1-1-3'
children: [
id: 'item1-1-3-1'
]
,
]
,
id: 'item1-2',
children: [
id: 'item1-2-1'
]

]
,
id: 'item2'
]


What I want to is like below,



function getFullDepthOfObject()
...


getFullIndexOfObject('item1') =====> return '1'
getFullIndexOfObject('item1-2') =====> return '1-2'
getFullIndexOfObject('item1-1-1') =====> return '1-1-1'
getFullIndexOfObject('item1-1-2') =====> return '1-1-2'
getFullIndexOfObject('item2') ===> return '2'


I have struggled with this too much time, But I couldn't make it. I think I should stack each of parent index, But I don't know how to get its parent. Is there a way to do this?



Not parse of id string. Each id has randomic string. The id like item1-2 is for easier demonstration.



I think my way is too verbose...
I tried like ...



// Get Full Index of item1-1


// First, get the target's depth.
var depth = 0;

function getDepthOfId(object, id)
var level;
if (object.id === id) return 1;
object.children && object.children.some(o => level = getDepthOfId(o, id));
return level && level + 1;


depth = getDepthOfId(items[0], 'item1-1');
console.log('depth === ', depth)


// Then, iterate recursively with length of depth.

var indexStacks = [];


function getNestedIndexOfId(obj, id, index)
if (obj.id === id)
indexStacks = [index, ...indexStacks]
return index;


if (obj.children)
depth++;
obj.children.map((child, i) =>
getNestedIndexOfId(child, id, i)
)



// I can get the inner index, but I can't get its parent id.
// I don't know how to this..

function getParentId(obj, id)
// ...?
var parentId;
return parentId;


for(var i=0; i<depth; i++)
getNestedIndexOfId('...')



// full path will be
indexStacks.join('-')









share|improve this question



















  • 1





    Wouldn't this suffice? getFullIndexOfObject = index =>index.replace('item', ''); This looks like this is result you are looking for

    – Miroslav Glamuzina
    Mar 9 at 3:15












  • @MiroslavGlamuzina The item's id is for easier understood, my code has id with uuid

    – Juntae
    Mar 9 at 3:19











  • What does the real code look like? Because even if it is but it is still in the format item__UUID__ this would still be valid.

    – Miroslav Glamuzina
    Mar 9 at 3:30













0












0








0








const items = [
id: 'item1',
children: [
id: 'item1-1',
children: [
id: 'item1-1-1' ,
id: 'item1-1-2' ,
id: 'item1-1-3'
children: [
id: 'item1-1-3-1'
]
,
]
,
id: 'item1-2',
children: [
id: 'item1-2-1'
]

]
,
id: 'item2'
]


What I want to is like below,



function getFullDepthOfObject()
...


getFullIndexOfObject('item1') =====> return '1'
getFullIndexOfObject('item1-2') =====> return '1-2'
getFullIndexOfObject('item1-1-1') =====> return '1-1-1'
getFullIndexOfObject('item1-1-2') =====> return '1-1-2'
getFullIndexOfObject('item2') ===> return '2'


I have struggled with this too much time, But I couldn't make it. I think I should stack each of parent index, But I don't know how to get its parent. Is there a way to do this?



Not parse of id string. Each id has randomic string. The id like item1-2 is for easier demonstration.



I think my way is too verbose...
I tried like ...



// Get Full Index of item1-1


// First, get the target's depth.
var depth = 0;

function getDepthOfId(object, id)
var level;
if (object.id === id) return 1;
object.children && object.children.some(o => level = getDepthOfId(o, id));
return level && level + 1;


depth = getDepthOfId(items[0], 'item1-1');
console.log('depth === ', depth)


// Then, iterate recursively with length of depth.

var indexStacks = [];


function getNestedIndexOfId(obj, id, index)
if (obj.id === id)
indexStacks = [index, ...indexStacks]
return index;


if (obj.children)
depth++;
obj.children.map((child, i) =>
getNestedIndexOfId(child, id, i)
)



// I can get the inner index, but I can't get its parent id.
// I don't know how to this..

function getParentId(obj, id)
// ...?
var parentId;
return parentId;


for(var i=0; i<depth; i++)
getNestedIndexOfId('...')



// full path will be
indexStacks.join('-')









share|improve this question
















const items = [
id: 'item1',
children: [
id: 'item1-1',
children: [
id: 'item1-1-1' ,
id: 'item1-1-2' ,
id: 'item1-1-3'
children: [
id: 'item1-1-3-1'
]
,
]
,
id: 'item1-2',
children: [
id: 'item1-2-1'
]

]
,
id: 'item2'
]


What I want to is like below,



function getFullDepthOfObject()
...


getFullIndexOfObject('item1') =====> return '1'
getFullIndexOfObject('item1-2') =====> return '1-2'
getFullIndexOfObject('item1-1-1') =====> return '1-1-1'
getFullIndexOfObject('item1-1-2') =====> return '1-1-2'
getFullIndexOfObject('item2') ===> return '2'


I have struggled with this too much time, But I couldn't make it. I think I should stack each of parent index, But I don't know how to get its parent. Is there a way to do this?



Not parse of id string. Each id has randomic string. The id like item1-2 is for easier demonstration.



I think my way is too verbose...
I tried like ...



// Get Full Index of item1-1


// First, get the target's depth.
var depth = 0;

function getDepthOfId(object, id)
var level;
if (object.id === id) return 1;
object.children && object.children.some(o => level = getDepthOfId(o, id));
return level && level + 1;


depth = getDepthOfId(items[0], 'item1-1');
console.log('depth === ', depth)


// Then, iterate recursively with length of depth.

var indexStacks = [];


function getNestedIndexOfId(obj, id, index)
if (obj.id === id)
indexStacks = [index, ...indexStacks]
return index;


if (obj.children)
depth++;
obj.children.map((child, i) =>
getNestedIndexOfId(child, id, i)
)



// I can get the inner index, but I can't get its parent id.
// I don't know how to this..

function getParentId(obj, id)
// ...?
var parentId;
return parentId;


for(var i=0; i<depth; i++)
getNestedIndexOfId('...')



// full path will be
indexStacks.join('-')






javascript






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Mar 9 at 4:29







Juntae

















asked Mar 9 at 3:06









JuntaeJuntae

1,61852764




1,61852764







  • 1





    Wouldn't this suffice? getFullIndexOfObject = index =>index.replace('item', ''); This looks like this is result you are looking for

    – Miroslav Glamuzina
    Mar 9 at 3:15












  • @MiroslavGlamuzina The item's id is for easier understood, my code has id with uuid

    – Juntae
    Mar 9 at 3:19











  • What does the real code look like? Because even if it is but it is still in the format item__UUID__ this would still be valid.

    – Miroslav Glamuzina
    Mar 9 at 3:30












  • 1





    Wouldn't this suffice? getFullIndexOfObject = index =>index.replace('item', ''); This looks like this is result you are looking for

    – Miroslav Glamuzina
    Mar 9 at 3:15












  • @MiroslavGlamuzina The item's id is for easier understood, my code has id with uuid

    – Juntae
    Mar 9 at 3:19











  • What does the real code look like? Because even if it is but it is still in the format item__UUID__ this would still be valid.

    – Miroslav Glamuzina
    Mar 9 at 3:30







1




1





Wouldn't this suffice? getFullIndexOfObject = index =>index.replace('item', ''); This looks like this is result you are looking for

– Miroslav Glamuzina
Mar 9 at 3:15






Wouldn't this suffice? getFullIndexOfObject = index =>index.replace('item', ''); This looks like this is result you are looking for

– Miroslav Glamuzina
Mar 9 at 3:15














@MiroslavGlamuzina The item's id is for easier understood, my code has id with uuid

– Juntae
Mar 9 at 3:19





@MiroslavGlamuzina The item's id is for easier understood, my code has id with uuid

– Juntae
Mar 9 at 3:19













What does the real code look like? Because even if it is but it is still in the format item__UUID__ this would still be valid.

– Miroslav Glamuzina
Mar 9 at 3:30





What does the real code look like? Because even if it is but it is still in the format item__UUID__ this would still be valid.

– Miroslav Glamuzina
Mar 9 at 3:30












5 Answers
5






active

oldest

votes


















2














const items = [
id: 'item1',
children: [
id: 'item1-1',
children: [
id: 'item1-1-1' ,
id: 'item1-1-2' ,
id: 'item1-1-3',
children: [
id: 'item1-1-3-1'
]

]
,
id: 'item1-2',
children: [
id: 'item1-2-1'
]

]
,
id: 'item2'
];

const searchIt = (node, search, path = '', position = 0) =>
if (node.id && node.id === search) return path !== '' ? `$path-$position` : position;
if (!node.children) return false
const index = node.children.findIndex((x) => x.id && x.id === search);
if (index >= 0)
return path !== '' ? `$path-$index + 1` : index + 1;

for (let i = 0; i < node.children.length; i++)
const result = searchIt(node.children[i], search, path !== '' ? `$path-$i+1` : i + 1, i);
if (result)
return result;


return false;
;

console.log(searchIt(children: items, 'item1-1'));
console.log(searchIt(children: items, 'item1-1-1'));
console.log(searchIt(children: items, 'item1-1-2'));
console.log(searchIt(children: items, 'item1-1-3'));
console.log(searchIt(children: items, 'item1-1-3-1'));
console.log(searchIt(children: items, 'item1-2-1'));
console.log(searchIt(children: items, 'item1-1-3-2'));
console.log(searchIt(children: items, 'item1-2-2'));
console.log(searchIt(children: items, 'item3'));





share|improve this answer






























    1














    You could take an recursive and iterative approach. On found, the path is returned from the most inner object to the outer call of the function.






    function getPath(array, id) 
    var result;
    array.some((o, i) =>
    var temp;
    if (o.id === id) return result = `$i + 1`;
    if (temp = getPath(o.children );
    return result;


    const items = [ id: 'item1', children: [ id: 'item1-1', children: [ id: 'item1-1-1' , id: 'item1-1-2' , id: 'item1-1-3', children: [ id: 'item1-1-3-1'] ] , id: 'item1-2', children: [ id: 'item1-2-1' ] ] , id: 'item2' ];


    console.log(getPath(items, 'item1')); // '1'
    console.log(getPath(items, 'item1-2')); // '1-2'
    console.log(getPath(items, 'item1-1-1')); // '1-1-1'
    console.log(getPath(items, 'item1-1-2')); // '1-1-2'
    console.log(getPath(items, 'item2')); // '2'








    share|improve this answer






























      0














      You can solve this problem using recursion. I have edited my code block and made it into a testable snippet. I had to fix an error in your data (missing comma or something don't remember).






      const items = [
      id: 'itemA',
      children: [
      id: 'item1-1',
      children: [
      id: 'item1-1-1' ,
      id: 'item1-1-2' ,
      id: 'item1-1-3', children: [ id: 'item1-1-3-1' ] ,
      ]
      ,
      id: 'item1-2', children: [ id: 'item1-2-1' ] ,
      ],
      ,
      id: 'item2'
      ];


      const getItemLevel = (targetKey, item, depth = 0) =>
      if (item.id === targetKey) return depth;
      let foundLevel = null;
      if (item.children)
      item.children.forEach((child) =>
      if (foundLevel) return;
      foundLevel = getItemLevel(targetKey, child, depth +1);
      )

      return foundLevel;


      console.log(getItemLevel('item1-1-1', id:'root', children: items ));
      console.log(getItemLevel('item2', id:'root', children: items ));
      console.log(getItemLevel('item1-1-3-1', id:'root', children: items ));
      console.log(getItemLevel('keydoesnotexist', id:'root', children: items ));








      share|improve this answer

























      • I think this does return just depth of item, not a full path. Please read my question again...Thanks.

        – Juntae
        Mar 9 at 3:42











      • He's already using recursion, but needs to see the parent/child/grandchild relationship.

        – lux
        Mar 9 at 3:50











      • ok clearly I don't understand the question then because I read and re-read it, and I am still not getting it. Maybe because his ids are confusing? What's the output you want?

        – JSager
        Mar 9 at 3:51











      • So like, if you had an item that was id "A" that was the child of "B" that was the child of "C", do you want the output to be "C-B-A"?

        – JSager
        Mar 9 at 3:52











      • @JSager That items index. Each item is inside an array. So, if the item item1-1-1 will print 1-1-1 From root to object, every index of its grandfather's index to its index. It's not actual index though, index + 1 actuaully.

        – Juntae
        Mar 9 at 4:14


















      0














      a simple way:



      const recursiveFind = (arr, id, res = indexes: [], found: false) => 
      if (!Array.isArray(arr)) return res

      const index = arr.findIndex(e => e.id === id)

      if (index < 0)
      for (let i = 0; i < arr.length; i++)
      res.indexes.push(i+1)
      const childIndexes = recursiveFind(arr[i].children, id, res)
      if (childIndexes.found)
      return childIndexes



      else
      res.found = true
      res.indexes.push(index+1)


      return res


      recursiveFind(items, 'item1-1-2').indexes.join('-')





      share|improve this answer






























        0














        If it's ok to use Lodash+Deepdash, then:



        let path;

        _.eachDeep(items,(val,key,parent,context)=>
        if(path) return false;
        if(val.id=='item1-1-2')
        path=context.path;
        return false;

        ,tree:true,pathFormat:'array');

        console.log(_(path).without('children').map(v=>parseInt(v)+1).join('-'));


        Here is a codepen for this






        share|improve this answer























          Your Answer






          StackExchange.ifUsing("editor", function ()
          StackExchange.using("externalEditor", function ()
          StackExchange.using("snippets", function ()
          StackExchange.snippets.init();
          );
          );
          , "code-snippets");

          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "1"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: true,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: 10,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );













          draft saved

          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55073607%2fjavascript-get-full-index-of-nested-object%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          5 Answers
          5






          active

          oldest

          votes








          5 Answers
          5






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          2














          const items = [
          id: 'item1',
          children: [
          id: 'item1-1',
          children: [
          id: 'item1-1-1' ,
          id: 'item1-1-2' ,
          id: 'item1-1-3',
          children: [
          id: 'item1-1-3-1'
          ]

          ]
          ,
          id: 'item1-2',
          children: [
          id: 'item1-2-1'
          ]

          ]
          ,
          id: 'item2'
          ];

          const searchIt = (node, search, path = '', position = 0) =>
          if (node.id && node.id === search) return path !== '' ? `$path-$position` : position;
          if (!node.children) return false
          const index = node.children.findIndex((x) => x.id && x.id === search);
          if (index >= 0)
          return path !== '' ? `$path-$index + 1` : index + 1;

          for (let i = 0; i < node.children.length; i++)
          const result = searchIt(node.children[i], search, path !== '' ? `$path-$i+1` : i + 1, i);
          if (result)
          return result;


          return false;
          ;

          console.log(searchIt(children: items, 'item1-1'));
          console.log(searchIt(children: items, 'item1-1-1'));
          console.log(searchIt(children: items, 'item1-1-2'));
          console.log(searchIt(children: items, 'item1-1-3'));
          console.log(searchIt(children: items, 'item1-1-3-1'));
          console.log(searchIt(children: items, 'item1-2-1'));
          console.log(searchIt(children: items, 'item1-1-3-2'));
          console.log(searchIt(children: items, 'item1-2-2'));
          console.log(searchIt(children: items, 'item3'));





          share|improve this answer



























            2














            const items = [
            id: 'item1',
            children: [
            id: 'item1-1',
            children: [
            id: 'item1-1-1' ,
            id: 'item1-1-2' ,
            id: 'item1-1-3',
            children: [
            id: 'item1-1-3-1'
            ]

            ]
            ,
            id: 'item1-2',
            children: [
            id: 'item1-2-1'
            ]

            ]
            ,
            id: 'item2'
            ];

            const searchIt = (node, search, path = '', position = 0) =>
            if (node.id && node.id === search) return path !== '' ? `$path-$position` : position;
            if (!node.children) return false
            const index = node.children.findIndex((x) => x.id && x.id === search);
            if (index >= 0)
            return path !== '' ? `$path-$index + 1` : index + 1;

            for (let i = 0; i < node.children.length; i++)
            const result = searchIt(node.children[i], search, path !== '' ? `$path-$i+1` : i + 1, i);
            if (result)
            return result;


            return false;
            ;

            console.log(searchIt(children: items, 'item1-1'));
            console.log(searchIt(children: items, 'item1-1-1'));
            console.log(searchIt(children: items, 'item1-1-2'));
            console.log(searchIt(children: items, 'item1-1-3'));
            console.log(searchIt(children: items, 'item1-1-3-1'));
            console.log(searchIt(children: items, 'item1-2-1'));
            console.log(searchIt(children: items, 'item1-1-3-2'));
            console.log(searchIt(children: items, 'item1-2-2'));
            console.log(searchIt(children: items, 'item3'));





            share|improve this answer

























              2












              2








              2







              const items = [
              id: 'item1',
              children: [
              id: 'item1-1',
              children: [
              id: 'item1-1-1' ,
              id: 'item1-1-2' ,
              id: 'item1-1-3',
              children: [
              id: 'item1-1-3-1'
              ]

              ]
              ,
              id: 'item1-2',
              children: [
              id: 'item1-2-1'
              ]

              ]
              ,
              id: 'item2'
              ];

              const searchIt = (node, search, path = '', position = 0) =>
              if (node.id && node.id === search) return path !== '' ? `$path-$position` : position;
              if (!node.children) return false
              const index = node.children.findIndex((x) => x.id && x.id === search);
              if (index >= 0)
              return path !== '' ? `$path-$index + 1` : index + 1;

              for (let i = 0; i < node.children.length; i++)
              const result = searchIt(node.children[i], search, path !== '' ? `$path-$i+1` : i + 1, i);
              if (result)
              return result;


              return false;
              ;

              console.log(searchIt(children: items, 'item1-1'));
              console.log(searchIt(children: items, 'item1-1-1'));
              console.log(searchIt(children: items, 'item1-1-2'));
              console.log(searchIt(children: items, 'item1-1-3'));
              console.log(searchIt(children: items, 'item1-1-3-1'));
              console.log(searchIt(children: items, 'item1-2-1'));
              console.log(searchIt(children: items, 'item1-1-3-2'));
              console.log(searchIt(children: items, 'item1-2-2'));
              console.log(searchIt(children: items, 'item3'));





              share|improve this answer













              const items = [
              id: 'item1',
              children: [
              id: 'item1-1',
              children: [
              id: 'item1-1-1' ,
              id: 'item1-1-2' ,
              id: 'item1-1-3',
              children: [
              id: 'item1-1-3-1'
              ]

              ]
              ,
              id: 'item1-2',
              children: [
              id: 'item1-2-1'
              ]

              ]
              ,
              id: 'item2'
              ];

              const searchIt = (node, search, path = '', position = 0) =>
              if (node.id && node.id === search) return path !== '' ? `$path-$position` : position;
              if (!node.children) return false
              const index = node.children.findIndex((x) => x.id && x.id === search);
              if (index >= 0)
              return path !== '' ? `$path-$index + 1` : index + 1;

              for (let i = 0; i < node.children.length; i++)
              const result = searchIt(node.children[i], search, path !== '' ? `$path-$i+1` : i + 1, i);
              if (result)
              return result;


              return false;
              ;

              console.log(searchIt(children: items, 'item1-1'));
              console.log(searchIt(children: items, 'item1-1-1'));
              console.log(searchIt(children: items, 'item1-1-2'));
              console.log(searchIt(children: items, 'item1-1-3'));
              console.log(searchIt(children: items, 'item1-1-3-1'));
              console.log(searchIt(children: items, 'item1-2-1'));
              console.log(searchIt(children: items, 'item1-1-3-2'));
              console.log(searchIt(children: items, 'item1-2-2'));
              console.log(searchIt(children: items, 'item3'));






              share|improve this answer












              share|improve this answer



              share|improve this answer










              answered Mar 9 at 4:24









              Thilina HasanthaThilina Hasantha

              1315




              1315























                  1














                  You could take an recursive and iterative approach. On found, the path is returned from the most inner object to the outer call of the function.






                  function getPath(array, id) 
                  var result;
                  array.some((o, i) =>
                  var temp;
                  if (o.id === id) return result = `$i + 1`;
                  if (temp = getPath(o.children );
                  return result;


                  const items = [ id: 'item1', children: [ id: 'item1-1', children: [ id: 'item1-1-1' , id: 'item1-1-2' , id: 'item1-1-3', children: [ id: 'item1-1-3-1'] ] , id: 'item1-2', children: [ id: 'item1-2-1' ] ] , id: 'item2' ];


                  console.log(getPath(items, 'item1')); // '1'
                  console.log(getPath(items, 'item1-2')); // '1-2'
                  console.log(getPath(items, 'item1-1-1')); // '1-1-1'
                  console.log(getPath(items, 'item1-1-2')); // '1-1-2'
                  console.log(getPath(items, 'item2')); // '2'








                  share|improve this answer



























                    1














                    You could take an recursive and iterative approach. On found, the path is returned from the most inner object to the outer call of the function.






                    function getPath(array, id) 
                    var result;
                    array.some((o, i) =>
                    var temp;
                    if (o.id === id) return result = `$i + 1`;
                    if (temp = getPath(o.children );
                    return result;


                    const items = [ id: 'item1', children: [ id: 'item1-1', children: [ id: 'item1-1-1' , id: 'item1-1-2' , id: 'item1-1-3', children: [ id: 'item1-1-3-1'] ] , id: 'item1-2', children: [ id: 'item1-2-1' ] ] , id: 'item2' ];


                    console.log(getPath(items, 'item1')); // '1'
                    console.log(getPath(items, 'item1-2')); // '1-2'
                    console.log(getPath(items, 'item1-1-1')); // '1-1-1'
                    console.log(getPath(items, 'item1-1-2')); // '1-1-2'
                    console.log(getPath(items, 'item2')); // '2'








                    share|improve this answer

























                      1












                      1








                      1







                      You could take an recursive and iterative approach. On found, the path is returned from the most inner object to the outer call of the function.






                      function getPath(array, id) 
                      var result;
                      array.some((o, i) =>
                      var temp;
                      if (o.id === id) return result = `$i + 1`;
                      if (temp = getPath(o.children );
                      return result;


                      const items = [ id: 'item1', children: [ id: 'item1-1', children: [ id: 'item1-1-1' , id: 'item1-1-2' , id: 'item1-1-3', children: [ id: 'item1-1-3-1'] ] , id: 'item1-2', children: [ id: 'item1-2-1' ] ] , id: 'item2' ];


                      console.log(getPath(items, 'item1')); // '1'
                      console.log(getPath(items, 'item1-2')); // '1-2'
                      console.log(getPath(items, 'item1-1-1')); // '1-1-1'
                      console.log(getPath(items, 'item1-1-2')); // '1-1-2'
                      console.log(getPath(items, 'item2')); // '2'








                      share|improve this answer













                      You could take an recursive and iterative approach. On found, the path is returned from the most inner object to the outer call of the function.






                      function getPath(array, id) 
                      var result;
                      array.some((o, i) =>
                      var temp;
                      if (o.id === id) return result = `$i + 1`;
                      if (temp = getPath(o.children );
                      return result;


                      const items = [ id: 'item1', children: [ id: 'item1-1', children: [ id: 'item1-1-1' , id: 'item1-1-2' , id: 'item1-1-3', children: [ id: 'item1-1-3-1'] ] , id: 'item1-2', children: [ id: 'item1-2-1' ] ] , id: 'item2' ];


                      console.log(getPath(items, 'item1')); // '1'
                      console.log(getPath(items, 'item1-2')); // '1-2'
                      console.log(getPath(items, 'item1-1-1')); // '1-1-1'
                      console.log(getPath(items, 'item1-1-2')); // '1-1-2'
                      console.log(getPath(items, 'item2')); // '2'








                      function getPath(array, id) 
                      var result;
                      array.some((o, i) =>
                      var temp;
                      if (o.id === id) return result = `$i + 1`;
                      if (temp = getPath(o.children );
                      return result;


                      const items = [ id: 'item1', children: [ id: 'item1-1', children: [ id: 'item1-1-1' , id: 'item1-1-2' , id: 'item1-1-3', children: [ id: 'item1-1-3-1'] ] , id: 'item1-2', children: [ id: 'item1-2-1' ] ] , id: 'item2' ];


                      console.log(getPath(items, 'item1')); // '1'
                      console.log(getPath(items, 'item1-2')); // '1-2'
                      console.log(getPath(items, 'item1-1-1')); // '1-1-1'
                      console.log(getPath(items, 'item1-1-2')); // '1-1-2'
                      console.log(getPath(items, 'item2')); // '2'





                      function getPath(array, id) 
                      var result;
                      array.some((o, i) =>
                      var temp;
                      if (o.id === id) return result = `$i + 1`;
                      if (temp = getPath(o.children );
                      return result;


                      const items = [ id: 'item1', children: [ id: 'item1-1', children: [ id: 'item1-1-1' , id: 'item1-1-2' , id: 'item1-1-3', children: [ id: 'item1-1-3-1'] ] , id: 'item1-2', children: [ id: 'item1-2-1' ] ] , id: 'item2' ];


                      console.log(getPath(items, 'item1')); // '1'
                      console.log(getPath(items, 'item1-2')); // '1-2'
                      console.log(getPath(items, 'item1-1-1')); // '1-1-1'
                      console.log(getPath(items, 'item1-1-2')); // '1-1-2'
                      console.log(getPath(items, 'item2')); // '2'






                      share|improve this answer












                      share|improve this answer



                      share|improve this answer










                      answered Mar 9 at 8:17









                      Nina ScholzNina Scholz

                      200k15112182




                      200k15112182





















                          0














                          You can solve this problem using recursion. I have edited my code block and made it into a testable snippet. I had to fix an error in your data (missing comma or something don't remember).






                          const items = [
                          id: 'itemA',
                          children: [
                          id: 'item1-1',
                          children: [
                          id: 'item1-1-1' ,
                          id: 'item1-1-2' ,
                          id: 'item1-1-3', children: [ id: 'item1-1-3-1' ] ,
                          ]
                          ,
                          id: 'item1-2', children: [ id: 'item1-2-1' ] ,
                          ],
                          ,
                          id: 'item2'
                          ];


                          const getItemLevel = (targetKey, item, depth = 0) =>
                          if (item.id === targetKey) return depth;
                          let foundLevel = null;
                          if (item.children)
                          item.children.forEach((child) =>
                          if (foundLevel) return;
                          foundLevel = getItemLevel(targetKey, child, depth +1);
                          )

                          return foundLevel;


                          console.log(getItemLevel('item1-1-1', id:'root', children: items ));
                          console.log(getItemLevel('item2', id:'root', children: items ));
                          console.log(getItemLevel('item1-1-3-1', id:'root', children: items ));
                          console.log(getItemLevel('keydoesnotexist', id:'root', children: items ));








                          share|improve this answer

























                          • I think this does return just depth of item, not a full path. Please read my question again...Thanks.

                            – Juntae
                            Mar 9 at 3:42











                          • He's already using recursion, but needs to see the parent/child/grandchild relationship.

                            – lux
                            Mar 9 at 3:50











                          • ok clearly I don't understand the question then because I read and re-read it, and I am still not getting it. Maybe because his ids are confusing? What's the output you want?

                            – JSager
                            Mar 9 at 3:51











                          • So like, if you had an item that was id "A" that was the child of "B" that was the child of "C", do you want the output to be "C-B-A"?

                            – JSager
                            Mar 9 at 3:52











                          • @JSager That items index. Each item is inside an array. So, if the item item1-1-1 will print 1-1-1 From root to object, every index of its grandfather's index to its index. It's not actual index though, index + 1 actuaully.

                            – Juntae
                            Mar 9 at 4:14















                          0














                          You can solve this problem using recursion. I have edited my code block and made it into a testable snippet. I had to fix an error in your data (missing comma or something don't remember).






                          const items = [
                          id: 'itemA',
                          children: [
                          id: 'item1-1',
                          children: [
                          id: 'item1-1-1' ,
                          id: 'item1-1-2' ,
                          id: 'item1-1-3', children: [ id: 'item1-1-3-1' ] ,
                          ]
                          ,
                          id: 'item1-2', children: [ id: 'item1-2-1' ] ,
                          ],
                          ,
                          id: 'item2'
                          ];


                          const getItemLevel = (targetKey, item, depth = 0) =>
                          if (item.id === targetKey) return depth;
                          let foundLevel = null;
                          if (item.children)
                          item.children.forEach((child) =>
                          if (foundLevel) return;
                          foundLevel = getItemLevel(targetKey, child, depth +1);
                          )

                          return foundLevel;


                          console.log(getItemLevel('item1-1-1', id:'root', children: items ));
                          console.log(getItemLevel('item2', id:'root', children: items ));
                          console.log(getItemLevel('item1-1-3-1', id:'root', children: items ));
                          console.log(getItemLevel('keydoesnotexist', id:'root', children: items ));








                          share|improve this answer

























                          • I think this does return just depth of item, not a full path. Please read my question again...Thanks.

                            – Juntae
                            Mar 9 at 3:42











                          • He's already using recursion, but needs to see the parent/child/grandchild relationship.

                            – lux
                            Mar 9 at 3:50











                          • ok clearly I don't understand the question then because I read and re-read it, and I am still not getting it. Maybe because his ids are confusing? What's the output you want?

                            – JSager
                            Mar 9 at 3:51











                          • So like, if you had an item that was id "A" that was the child of "B" that was the child of "C", do you want the output to be "C-B-A"?

                            – JSager
                            Mar 9 at 3:52











                          • @JSager That items index. Each item is inside an array. So, if the item item1-1-1 will print 1-1-1 From root to object, every index of its grandfather's index to its index. It's not actual index though, index + 1 actuaully.

                            – Juntae
                            Mar 9 at 4:14













                          0












                          0








                          0







                          You can solve this problem using recursion. I have edited my code block and made it into a testable snippet. I had to fix an error in your data (missing comma or something don't remember).






                          const items = [
                          id: 'itemA',
                          children: [
                          id: 'item1-1',
                          children: [
                          id: 'item1-1-1' ,
                          id: 'item1-1-2' ,
                          id: 'item1-1-3', children: [ id: 'item1-1-3-1' ] ,
                          ]
                          ,
                          id: 'item1-2', children: [ id: 'item1-2-1' ] ,
                          ],
                          ,
                          id: 'item2'
                          ];


                          const getItemLevel = (targetKey, item, depth = 0) =>
                          if (item.id === targetKey) return depth;
                          let foundLevel = null;
                          if (item.children)
                          item.children.forEach((child) =>
                          if (foundLevel) return;
                          foundLevel = getItemLevel(targetKey, child, depth +1);
                          )

                          return foundLevel;


                          console.log(getItemLevel('item1-1-1', id:'root', children: items ));
                          console.log(getItemLevel('item2', id:'root', children: items ));
                          console.log(getItemLevel('item1-1-3-1', id:'root', children: items ));
                          console.log(getItemLevel('keydoesnotexist', id:'root', children: items ));








                          share|improve this answer















                          You can solve this problem using recursion. I have edited my code block and made it into a testable snippet. I had to fix an error in your data (missing comma or something don't remember).






                          const items = [
                          id: 'itemA',
                          children: [
                          id: 'item1-1',
                          children: [
                          id: 'item1-1-1' ,
                          id: 'item1-1-2' ,
                          id: 'item1-1-3', children: [ id: 'item1-1-3-1' ] ,
                          ]
                          ,
                          id: 'item1-2', children: [ id: 'item1-2-1' ] ,
                          ],
                          ,
                          id: 'item2'
                          ];


                          const getItemLevel = (targetKey, item, depth = 0) =>
                          if (item.id === targetKey) return depth;
                          let foundLevel = null;
                          if (item.children)
                          item.children.forEach((child) =>
                          if (foundLevel) return;
                          foundLevel = getItemLevel(targetKey, child, depth +1);
                          )

                          return foundLevel;


                          console.log(getItemLevel('item1-1-1', id:'root', children: items ));
                          console.log(getItemLevel('item2', id:'root', children: items ));
                          console.log(getItemLevel('item1-1-3-1', id:'root', children: items ));
                          console.log(getItemLevel('keydoesnotexist', id:'root', children: items ));








                          const items = [
                          id: 'itemA',
                          children: [
                          id: 'item1-1',
                          children: [
                          id: 'item1-1-1' ,
                          id: 'item1-1-2' ,
                          id: 'item1-1-3', children: [ id: 'item1-1-3-1' ] ,
                          ]
                          ,
                          id: 'item1-2', children: [ id: 'item1-2-1' ] ,
                          ],
                          ,
                          id: 'item2'
                          ];


                          const getItemLevel = (targetKey, item, depth = 0) =>
                          if (item.id === targetKey) return depth;
                          let foundLevel = null;
                          if (item.children)
                          item.children.forEach((child) =>
                          if (foundLevel) return;
                          foundLevel = getItemLevel(targetKey, child, depth +1);
                          )

                          return foundLevel;


                          console.log(getItemLevel('item1-1-1', id:'root', children: items ));
                          console.log(getItemLevel('item2', id:'root', children: items ));
                          console.log(getItemLevel('item1-1-3-1', id:'root', children: items ));
                          console.log(getItemLevel('keydoesnotexist', id:'root', children: items ));





                          const items = [
                          id: 'itemA',
                          children: [
                          id: 'item1-1',
                          children: [
                          id: 'item1-1-1' ,
                          id: 'item1-1-2' ,
                          id: 'item1-1-3', children: [ id: 'item1-1-3-1' ] ,
                          ]
                          ,
                          id: 'item1-2', children: [ id: 'item1-2-1' ] ,
                          ],
                          ,
                          id: 'item2'
                          ];


                          const getItemLevel = (targetKey, item, depth = 0) =>
                          if (item.id === targetKey) return depth;
                          let foundLevel = null;
                          if (item.children)
                          item.children.forEach((child) =>
                          if (foundLevel) return;
                          foundLevel = getItemLevel(targetKey, child, depth +1);
                          )

                          return foundLevel;


                          console.log(getItemLevel('item1-1-1', id:'root', children: items ));
                          console.log(getItemLevel('item2', id:'root', children: items ));
                          console.log(getItemLevel('item1-1-3-1', id:'root', children: items ));
                          console.log(getItemLevel('keydoesnotexist', id:'root', children: items ));






                          share|improve this answer














                          share|improve this answer



                          share|improve this answer








                          edited Mar 9 at 3:50

























                          answered Mar 9 at 3:36









                          JSagerJSager

                          1,215714




                          1,215714












                          • I think this does return just depth of item, not a full path. Please read my question again...Thanks.

                            – Juntae
                            Mar 9 at 3:42











                          • He's already using recursion, but needs to see the parent/child/grandchild relationship.

                            – lux
                            Mar 9 at 3:50











                          • ok clearly I don't understand the question then because I read and re-read it, and I am still not getting it. Maybe because his ids are confusing? What's the output you want?

                            – JSager
                            Mar 9 at 3:51











                          • So like, if you had an item that was id "A" that was the child of "B" that was the child of "C", do you want the output to be "C-B-A"?

                            – JSager
                            Mar 9 at 3:52











                          • @JSager That items index. Each item is inside an array. So, if the item item1-1-1 will print 1-1-1 From root to object, every index of its grandfather's index to its index. It's not actual index though, index + 1 actuaully.

                            – Juntae
                            Mar 9 at 4:14

















                          • I think this does return just depth of item, not a full path. Please read my question again...Thanks.

                            – Juntae
                            Mar 9 at 3:42











                          • He's already using recursion, but needs to see the parent/child/grandchild relationship.

                            – lux
                            Mar 9 at 3:50











                          • ok clearly I don't understand the question then because I read and re-read it, and I am still not getting it. Maybe because his ids are confusing? What's the output you want?

                            – JSager
                            Mar 9 at 3:51











                          • So like, if you had an item that was id "A" that was the child of "B" that was the child of "C", do you want the output to be "C-B-A"?

                            – JSager
                            Mar 9 at 3:52











                          • @JSager That items index. Each item is inside an array. So, if the item item1-1-1 will print 1-1-1 From root to object, every index of its grandfather's index to its index. It's not actual index though, index + 1 actuaully.

                            – Juntae
                            Mar 9 at 4:14
















                          I think this does return just depth of item, not a full path. Please read my question again...Thanks.

                          – Juntae
                          Mar 9 at 3:42





                          I think this does return just depth of item, not a full path. Please read my question again...Thanks.

                          – Juntae
                          Mar 9 at 3:42













                          He's already using recursion, but needs to see the parent/child/grandchild relationship.

                          – lux
                          Mar 9 at 3:50





                          He's already using recursion, but needs to see the parent/child/grandchild relationship.

                          – lux
                          Mar 9 at 3:50













                          ok clearly I don't understand the question then because I read and re-read it, and I am still not getting it. Maybe because his ids are confusing? What's the output you want?

                          – JSager
                          Mar 9 at 3:51





                          ok clearly I don't understand the question then because I read and re-read it, and I am still not getting it. Maybe because his ids are confusing? What's the output you want?

                          – JSager
                          Mar 9 at 3:51













                          So like, if you had an item that was id "A" that was the child of "B" that was the child of "C", do you want the output to be "C-B-A"?

                          – JSager
                          Mar 9 at 3:52





                          So like, if you had an item that was id "A" that was the child of "B" that was the child of "C", do you want the output to be "C-B-A"?

                          – JSager
                          Mar 9 at 3:52













                          @JSager That items index. Each item is inside an array. So, if the item item1-1-1 will print 1-1-1 From root to object, every index of its grandfather's index to its index. It's not actual index though, index + 1 actuaully.

                          – Juntae
                          Mar 9 at 4:14





                          @JSager That items index. Each item is inside an array. So, if the item item1-1-1 will print 1-1-1 From root to object, every index of its grandfather's index to its index. It's not actual index though, index + 1 actuaully.

                          – Juntae
                          Mar 9 at 4:14











                          0














                          a simple way:



                          const recursiveFind = (arr, id, res = indexes: [], found: false) => 
                          if (!Array.isArray(arr)) return res

                          const index = arr.findIndex(e => e.id === id)

                          if (index < 0)
                          for (let i = 0; i < arr.length; i++)
                          res.indexes.push(i+1)
                          const childIndexes = recursiveFind(arr[i].children, id, res)
                          if (childIndexes.found)
                          return childIndexes



                          else
                          res.found = true
                          res.indexes.push(index+1)


                          return res


                          recursiveFind(items, 'item1-1-2').indexes.join('-')





                          share|improve this answer



























                            0














                            a simple way:



                            const recursiveFind = (arr, id, res = indexes: [], found: false) => 
                            if (!Array.isArray(arr)) return res

                            const index = arr.findIndex(e => e.id === id)

                            if (index < 0)
                            for (let i = 0; i < arr.length; i++)
                            res.indexes.push(i+1)
                            const childIndexes = recursiveFind(arr[i].children, id, res)
                            if (childIndexes.found)
                            return childIndexes



                            else
                            res.found = true
                            res.indexes.push(index+1)


                            return res


                            recursiveFind(items, 'item1-1-2').indexes.join('-')





                            share|improve this answer

























                              0












                              0








                              0







                              a simple way:



                              const recursiveFind = (arr, id, res = indexes: [], found: false) => 
                              if (!Array.isArray(arr)) return res

                              const index = arr.findIndex(e => e.id === id)

                              if (index < 0)
                              for (let i = 0; i < arr.length; i++)
                              res.indexes.push(i+1)
                              const childIndexes = recursiveFind(arr[i].children, id, res)
                              if (childIndexes.found)
                              return childIndexes



                              else
                              res.found = true
                              res.indexes.push(index+1)


                              return res


                              recursiveFind(items, 'item1-1-2').indexes.join('-')





                              share|improve this answer













                              a simple way:



                              const recursiveFind = (arr, id, res = indexes: [], found: false) => 
                              if (!Array.isArray(arr)) return res

                              const index = arr.findIndex(e => e.id === id)

                              if (index < 0)
                              for (let i = 0; i < arr.length; i++)
                              res.indexes.push(i+1)
                              const childIndexes = recursiveFind(arr[i].children, id, res)
                              if (childIndexes.found)
                              return childIndexes



                              else
                              res.found = true
                              res.indexes.push(index+1)


                              return res


                              recursiveFind(items, 'item1-1-2').indexes.join('-')






                              share|improve this answer












                              share|improve this answer



                              share|improve this answer










                              answered Mar 9 at 5:46









                              Andre FigueiredoAndre Figueiredo

                              7,73653463




                              7,73653463





















                                  0














                                  If it's ok to use Lodash+Deepdash, then:



                                  let path;

                                  _.eachDeep(items,(val,key,parent,context)=>
                                  if(path) return false;
                                  if(val.id=='item1-1-2')
                                  path=context.path;
                                  return false;

                                  ,tree:true,pathFormat:'array');

                                  console.log(_(path).without('children').map(v=>parseInt(v)+1).join('-'));


                                  Here is a codepen for this






                                  share|improve this answer



























                                    0














                                    If it's ok to use Lodash+Deepdash, then:



                                    let path;

                                    _.eachDeep(items,(val,key,parent,context)=>
                                    if(path) return false;
                                    if(val.id=='item1-1-2')
                                    path=context.path;
                                    return false;

                                    ,tree:true,pathFormat:'array');

                                    console.log(_(path).without('children').map(v=>parseInt(v)+1).join('-'));


                                    Here is a codepen for this






                                    share|improve this answer

























                                      0












                                      0








                                      0







                                      If it's ok to use Lodash+Deepdash, then:



                                      let path;

                                      _.eachDeep(items,(val,key,parent,context)=>
                                      if(path) return false;
                                      if(val.id=='item1-1-2')
                                      path=context.path;
                                      return false;

                                      ,tree:true,pathFormat:'array');

                                      console.log(_(path).without('children').map(v=>parseInt(v)+1).join('-'));


                                      Here is a codepen for this






                                      share|improve this answer













                                      If it's ok to use Lodash+Deepdash, then:



                                      let path;

                                      _.eachDeep(items,(val,key,parent,context)=>
                                      if(path) return false;
                                      if(val.id=='item1-1-2')
                                      path=context.path;
                                      return false;

                                      ,tree:true,pathFormat:'array');

                                      console.log(_(path).without('children').map(v=>parseInt(v)+1).join('-'));


                                      Here is a codepen for this







                                      share|improve this answer












                                      share|improve this answer



                                      share|improve this answer










                                      answered Mar 11 at 21:24









                                      Yuri GorYuri Gor

                                      713416




                                      713416



























                                          draft saved

                                          draft discarded
















































                                          Thanks for contributing an answer to Stack Overflow!


                                          • Please be sure to answer the question. Provide details and share your research!

                                          But avoid


                                          • Asking for help, clarification, or responding to other answers.

                                          • Making statements based on opinion; back them up with references or personal experience.

                                          To learn more, see our tips on writing great answers.




                                          draft saved


                                          draft discarded














                                          StackExchange.ready(
                                          function ()
                                          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55073607%2fjavascript-get-full-index-of-nested-object%23new-answer', 'question_page');

                                          );

                                          Post as a guest















                                          Required, but never shown





















































                                          Required, but never shown














                                          Required, but never shown












                                          Required, but never shown







                                          Required, but never shown

































                                          Required, but never shown














                                          Required, but never shown












                                          Required, but never shown







                                          Required, but never shown







                                          Popular posts from this blog

                                          Save data to MySQL database using ExtJS and PHP [closed]2019 Community Moderator ElectionHow can I prevent SQL injection in PHP?Which MySQL data type to use for storing boolean valuesPHP: Delete an element from an arrayHow do I connect to a MySQL Database in Python?Should I use the datetime or timestamp data type in MySQL?How to get a list of MySQL user accountsHow Do You Parse and Process HTML/XML in PHP?Reference — What does this symbol mean in PHP?How does PHP 'foreach' actually work?Why shouldn't I use mysql_* functions in PHP?

                                          Compiling GNU Global with universal-ctags support Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern) Data science time! April 2019 and salary with experience The Ask Question Wizard is Live!Tags for Emacs: Relationship between etags, ebrowse, cscope, GNU Global and exuberant ctagsVim and Ctags tips and trickscscope or ctags why choose one over the other?scons and ctagsctags cannot open option file “.ctags”Adding tag scopes in universal-ctagsShould I use Universal-ctags?Universal ctags on WindowsHow do I install GNU Global with universal ctags support using Homebrew?Universal ctags with emacsHow to highlight ctags generated by Universal Ctags in Vim?

                                          Add ONERROR event to image from jsp tldHow to add an image to a JPanel?Saving image from PHP URLHTML img scalingCheck if an image is loaded (no errors) with jQueryHow to force an <img> to take up width, even if the image is not loadedHow do I populate hidden form field with a value set in Spring ControllerStyling Raw elements Generated from JSP tagds with Jquery MobileLimit resizing of images with explicitly set width and height attributeserror TLD use in a jsp fileJsp tld files cannot be resolved