--- id: 56533eb9ac21ba0edf2244cc title: Accessing Nested Objects challengeType: 1 videoUrl: 'https://scrimba.com/c/cRnRnfa' forumTopicId: 16161 --- ## Description
The sub-properties of objects can be accessed by chaining together the dot or bracket notation. Here is a nested object: ```js var ourStorage = { "desk": { "drawer": "stapler" }, "cabinet": { "top drawer": { "folder1": "a file", "folder2": "secrets" }, "bottom drawer": "soda" } }; ourStorage.cabinet["top drawer"].folder2; // "secrets" ourStorage.desk.drawer; // "stapler" ```
## Instructions
Access the myStorage object and assign the contents of the glove box property to the gloveBoxContents variable. Use dot notation for all properties where possible, otherwise use bracket notation.
## Tests
```yml tests: - text: gloveBoxContents should equal "maps". testString: assert(gloveBoxContents === "maps"); - text: Your code should use dot and bracket notation to access myStorage. testString: assert(/=\s*myStorage\.car\.inside\[\s*("|')glove box\1\s*\]/g.test(code)); ```
## Challenge Seed
```js // Setup var myStorage = { "car": { "inside": { "glove box": "maps", "passenger seat": "crumbs" }, "outside": { "trunk": "jack" } } }; var gloveBoxContents = undefined; // Change this line ```
### After Test
```js (function(x) { if(typeof x != 'undefined') { return "gloveBoxContents = " + x; } return "gloveBoxContents is undefined"; })(gloveBoxContents); ```
## Solution
```js var myStorage = { "car":{ "inside":{ "glove box":"maps", "passenger seat":"crumbs" }, "outside":{ "trunk":"jack" } } }; var gloveBoxContents = myStorage.car.inside["glove box"]; ```