Ony nested if works, why?

Tell us what’s happening:
Describe your issue in detail here.
when I try with normal if-else with logical comparison, it does not work and I don’t get why?

  **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 (name === contacts[i].firstName && contacts[i].hasOwnProperty(prop) === true) {
    return contacts[i][prop];
  }
  else if (name !== contacts[i].firstName){
    return "No such contact";
  }
  else if (contacts.hasOwnProperty(prop) !== true){
    return "No such property";
  }
}
// Only change code above this line
}

lookUpProfile("Akira", "likes");
  **Your browser information:**

User Agent is: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/96.0.4664.110 Safari/537.36

Challenge: Profile Lookup

Link to the challenge:

A return statement immediately stops your function, even in the middle of a loop.

so that means the first “if” should run at least, right?
and I’m still confused because the answer had a “return” after the second if, and it still ran the “else” that followed.

The body if the first if runs if the condition is true. The condition on your second else-if will always be true.

This topic was automatically closed 182 days after the last reply. New replies are no longer allowed.