* fix: move "Explore Differences Between..." to basic JS, update seed and tests * fix: resequence "Declare String Variables" * fix: move "Declare a Read-Only Variable..." to basic JS, update seed and tests * fix: revert changes to non-English "Explore Differences Between..." test text * fix: revert test strings, solutions, and seeds for non-English challenges * fix: update "Declare String Variables" description * fix: sync quotation marks in description and seed * fix: modify note in "Declare a Read-Only..." challenge * fix: update operator and compound assignment challenges * fix: update string challenges * fix: update array and array method challenges * fix: update function and scope challenges, resequence slightly * fix: "Word Blanks" solution * fix: add spacing to seed * fix: concatenating += challenge spacing * fix: appending variables to strings spacing * fix: find the length of a string spacing * fix: removed instances of removedFromMyArray = 0 * fix: switch challenges * fix: function argument and param spacing * fix: update counting cards, object challenges, and record collection * fix: finish rest of Basic JS section * fix: introducing else statements solution * fix: update spacing and wording * fix: update wording for const challenge * fix: update functional programming challenges * fix: intermediate algorithms and cert challenges * fix: revert some spacing and remove comments for fp challenge solutions * feat: add notes with links to moved let and const challenges in first two es6 challenges * fix: update es6 intro text * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/basic-javascript/concatenating-strings-with-the-plus-equals-operator.md Co-authored-by: Shaun Hamilton <shauhami020@gmail.com> * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/basic-javascript/finding-a-remainder-in-javascript.md Co-authored-by: Shaun Hamilton <shauhami020@gmail.com> * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/basic-javascript/global-scope-and-functions.md Co-authored-by: Shaun Hamilton <shauhami020@gmail.com> * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/basic-javascript/iterate-through-an-array-with-a-for-loop.md Co-authored-by: Shaun Hamilton <shauhami020@gmail.com> * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/basic-javascript/iterate-through-an-array-with-a-for-loop.md Co-authored-by: Shaun Hamilton <shauhami020@gmail.com> * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/functional-programming/implement-map-on-a-prototype.md Co-authored-by: Shaun Hamilton <shauhami020@gmail.com> * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/basic-javascript/declare-a-read-only-variable-with-the-const-keyword.md Co-authored-by: Shaun Hamilton <shauhami020@gmail.com> * fix: concatenating strings with plus operator seed * fix: add comments back to Declare a Read-Only Variable... seed * feat: add es6 to basic javascript redirect tests for let and const challenges * fix: revert "Concatenating Strings with Plus Operator" seed * fix: move test file to cypress/integration/learn/redirects, separate redirect tests Co-authored-by: Shaun Hamilton <shauhami020@gmail.com>
145 lines
3.2 KiB
Markdown
145 lines
3.2 KiB
Markdown
---
|
|
id: 5688e62ea601b2482ff8422b
|
|
title: Profile Lookup
|
|
challengeType: 1
|
|
videoUrl: 'https://scrimba.com/c/cDqW2Cg'
|
|
forumTopicId: 18259
|
|
dashedName: profile-lookup
|
|
---
|
|
|
|
# --description--
|
|
|
|
We have an array of objects representing different people in our contacts lists.
|
|
|
|
A `lookUpProfile` function that takes `name` and a property (`prop`) as arguments has been pre-written for you.
|
|
|
|
The function should check if `name` is an actual contact's `firstName` and the given property (`prop`) is a property of that contact.
|
|
|
|
If both are true, then return the "value" of that property.
|
|
|
|
If `name` does not correspond to any contacts then return the string `No such contact`.
|
|
|
|
If `prop` does not correspond to any valid properties of a contact found to match `name` then return the string `No such property`.
|
|
|
|
# --hints--
|
|
|
|
`lookUpProfile("Kristian", "lastName")` should return the string `Vos`
|
|
|
|
```js
|
|
assert(lookUpProfile('Kristian', 'lastName') === 'Vos');
|
|
```
|
|
|
|
`lookUpProfile("Sherlock", "likes")` should return `["Intriguing Cases", "Violin"]`
|
|
|
|
```js
|
|
assert.deepEqual(lookUpProfile('Sherlock', 'likes'), [
|
|
'Intriguing Cases',
|
|
'Violin'
|
|
]);
|
|
```
|
|
|
|
`lookUpProfile("Harry", "likes")` should return an array
|
|
|
|
```js
|
|
assert(typeof lookUpProfile('Harry', 'likes') === 'object');
|
|
```
|
|
|
|
`lookUpProfile("Bob", "number")` should return the string `No such contact`
|
|
|
|
```js
|
|
assert(lookUpProfile('Bob', 'number') === 'No such contact');
|
|
```
|
|
|
|
`lookUpProfile("Bob", "potato")` should return the string `No such contact`
|
|
|
|
```js
|
|
assert(lookUpProfile('Bob', 'potato') === 'No such contact');
|
|
```
|
|
|
|
`lookUpProfile("Akira", "address")` should return the string `No such property`
|
|
|
|
```js
|
|
assert(lookUpProfile('Akira', 'address') === 'No such property');
|
|
```
|
|
|
|
# --seed--
|
|
|
|
## --seed-contents--
|
|
|
|
```js
|
|
// 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
|
|
|
|
// Only change code above this line
|
|
}
|
|
|
|
lookUpProfile("Akira", "likes");
|
|
```
|
|
|
|
# --solutions--
|
|
|
|
```js
|
|
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) {
|
|
for (let i in contacts) {
|
|
if (contacts[i].firstName === name) {
|
|
return contacts[i][prop] || "No such property";
|
|
}
|
|
}
|
|
return "No such contact";
|
|
}
|
|
```
|