5

Consider the following array of JSON objects:

myList = [
    {title:"Parent1",
        children:[{childname:"Child11"},
                     {childname:"Child12"}],
        cars:[{carname:"Car11"},
              {carname:"Car12"}]
    },
    {title:"Parent2",
        children:[{childname:"Child21"},
                     {childname:"Child22"}],
        cars:[{carname:"Car21"},
              {carname:"Car22"}]
    }
];

How does one access the "Child21" in javascript? The following options didn't work:

var myString = myList[1].children[0].childname; //Does not work
var myString = myList[1]["children"][0].childname; //Does not work
PS2009
  • 51
  • 1
  • 1
  • 2

4 Answers4

9

This worked OK for me:

myList[1].children[0].childname

This is also OK:

myList[1]["children"][0].childname;

In full,

<html>
<body>
<script>
var myList = [
    {title:"Parent1",
        children:[{childname:"Child11"},
                     {childname:"Child12"}],
        cars:[{carname:"Car11"},
              {carname:"Car12"}]
    },
    {title:"Parent2",
        children:[{childname:"Child21"},
                     {childname:"Child22"}],
        cars:[{carname:"Car21"},
              {carname:"Car22"}]
    }
];
alert (myList[1].children[0].childname);
</script>
</body>
</html>
  • +1 to you and not the others because of the HTML example + 5 min earlier answer! – Seb Oct 30 '09 at 14:34
1

var myString = myList[1].children[0].childname;

In FireFox's Firebug works

sh1ng
  • 2,808
  • 4
  • 24
  • 38
0

This does work...

alert(myList[1].children[0].childname);
Josh Stodola
  • 81,538
  • 47
  • 180
  • 227
0

Your first option...

var myString = myList[1].children[0].childname;

should work just fine.

George
  • 7,864
  • 5
  • 29
  • 25