I am trying to get a specific field value from a nested array within an object array. I\'m assuming I\'d use map, but every time I use it in this way I get two empty arrays nest
Since array.find is not available in all browsers yet, and you may not be using a build tool, here is a complete ES5 way. It uses filter and map:
var data = [{ id: 12345678900, name: 'Jasmin', age: 27, hobbies: [{'id': 1221, 'name': 'hiking', 'when': 'anytime'}, { 'id': 9865, 'name': 'eating', 'when': 'all the time' }] }, { id: 223456789001, name: 'Joe', age: 35, hobbies: [{'id': 989, 'name':
'gaming', 'when': 'anytime'}, { 'id': 2355, 'name': 'online gaming', 'when': 'all the time' }]}];
function getHobbiesByName(name) {
return data.filter(function(person) {
return (person.name == name);
})[0].hobbies.map(function(hobby) {
return hobby.name
})
}
console.log(getHobbiesByName('Joe'))