Tell us what’s happening:
Can someone tell me why this isn’t passing? The errors are saying that the values for the existing props are not being returned. However, when I console.log before the return statement, it is returning/logging Akira’s “likes” just fine.
**Your code so far**
// Setup
const contacts = [
{
firstName: "Akira",
lastName: "Laine",
number: "0543236543",
likes: ["Pizza", "Coding", "Brownie Points"],
},
{
firstName: "Harry",
lastName: "Potter",
number: "0994372684",
likes: ["Hogwarts", "Magic", "Hagrid"],
},
{
firstName: "Sherlock",
lastName: "Holmes",
number: "0487345643",
likes: ["Intriguing Cases", "Violin"],
},
{
firstName: "Kristian",
lastName: "Vos",
number: "unknown",
likes: ["JavaScript", "Gaming", "Foxes"],
},
];
function lookUpProfile(name, prop) {
// Only change code below this line
for (let i = 0; i < contacts.length; i++)
{
if (contacts[i].firstName == name)
{
if (contacts[i].hasOwnProperty(prop))
{
console.log(contacts[i][prop]);
return contacts[i][prop];
} else
{
return "No such property";
}
} else
{
return "No such contact";
}
}
// Only change code above this line
}
lookUpProfile("Akira", "likes");
**Your browser information:**
User Agent is: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:99.0) Gecko/20100101 Firefox/99.0
I get the gist of what you’re saying. So, I got rid of that “else” and removed a couple of brackets, and moved the return to the end and now it’s passing.