In this section we will be explore how to represent more complex data in a nested data structure.
You will be placing all your code into the scripts.js file.
Let's think about the best data structure to represent a relationship between two animals in our collection. Imagine that our app has a 'friendslist' on an animal's profile which lists out all of the animal's friends. What do you think is the best way to represent this? Would you use an array or an object or some combination of both? Let's walk through the process together.
#####Create a Friendslist
- Choose a data structure (array or object) for the list of friends' usernames.
- Justify your decision.
- Create a variable called
friends
and assign it to the empty data structure. - Using your
animals
array, add two usernames tofriends
.- ensure that you are just putting the
username
value, not the entire object - be careful not to use a destructive method like
pop()
that will remove the whole value from the animals array.
- ensure that you are just putting the
- Inspect your
friends
data structure. What does it look like?
Imagine now that we have more than one kind of relationship in our app, we have friends and then we have romantic matches. Let's create an object to organize these different relationships!
- Create a variable called
relationships
assign it to an empty object. - Add your
friends
data structure to therelationships
object. - Inspect your object. What is it's length?
- Create a variable called
matches
and assign it to an empty array. - Add the
matches
array to therelationships
object. It should look like this:relationships = { friends: ['duck', 'camel'], matches: []}
- Using the
relationships
object, add at at least oneusername
tomatches
- Hint: the matches array is now nested inside the
relationships
object!
- Hint: the matches array is now nested inside the
- Inspect your object. Is the
matches
array now populated with some lucky animal? - Loop through your
animals
collection, adding therelationships
object to each animal object. Name the propertyrelationships
.- Note: it is ok that these are all the same
relationship
object.
- Note: it is ok that these are all the same