Basic JavaScript - Profile Lookup

Hey, I’m not sure of what I did wrong. When deleting the two else if, first if returns correctly, but when adding them the first if doesn’t work?..

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 && contacts[i].hasOwnProperty(prop)) {

      return contacts[i][prop];

    }

    else if (contacts[i].firstName !== name) {
      return "No such contact";
    }

    else if (contacts[i].hasOwnProperty(prop) == false) {

      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/108.0.0.0 Safari/537.36 OPR/94.0.0.0

Challenge: Basic JavaScript - Profile Lookup

Link to the challenge:

The very first return statement that is executed immediately stops the function.

Yeah, but why is it incorrect, shouldn’t it just return contacts[i][prop]?

You want to return a message if you find the right contact, yes, but do you want your function to step and give up when you find a contact that doesn’t match?

Ohh i understand, Thank you so much!

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