原题目链接:https://freecodecamp.cn/challenges/profile-lookup#

题目


    我们有一个对象数组,里面存储着通讯录。 函数 lookUp 有两个预定义参数:firstName值和prop属性 。函数将会检查通讯录中是否存在一个与传入的firstName相同的联系人。 如果存在,那么还需要检查对应的联系人中是否存在 prop属性。如果它们都存在,函数返回prop属性对应的值。如果firstName 值不存在,返回 "No such contact"。 如果prop 属性不存在,返回 "No such property"。

个人思路


    循环判断有与参数 firstName值 匹配的联系人;
        如果存在,那么继续判断是否存在参数 prop 匹配的属性;
            如果存在,就返回该属性的值,并结束循环。
            如果不存在,就返回"No such property",并结束循环。
    当循环到最后一个联系人却还没有匹配到时,就返回"No such contact",此时循环顺势结束了。 

数据测试


    "Kristian", "lastName" 应该返回 "Vos"
    "Sherlock", "likes" 应该返回 ["Intriguing Cases", "Violin"]
    "Harry","likes" 应该返回一个数组
    "Bob", "number" 应该返回 "No such contact"
    "Akira", "address" 应该返回 "No such property"

代码段(复制到控制台即可看结果,修改最后一行的参数完成测试。)

 1 //初始化变量
 2 var contacts = [
 3     {
 4         "firstName": "Akira",
 5         "lastName": "Laine",
 6         "number": "0543236543",
 7         "likes": ["Pizza", "Coding", "Brownie Points"]
 8     },
 9     {
10         "firstName": "Harry",
11         "lastName": "Potter",
12         "number": "0994372684",
13         "likes": ["Hogwarts", "Magic", "Hagrid"]
14     },
15     {
16         "firstName": "Sherlock",
17         "lastName": "Holmes",
18         "number": "0487345643",
19         "likes": ["Intriguing Cases", "Violin"]
20     },
21     {
22         "firstName": "Kristian",
23         "lastName": "Vos",
24         "number": "unknown",
25         "likes": ["Javascript", "Gaming", "Foxes"]
26     }
27 ];
28
29 function lookUp(firstName, prop){
30 // 请把你的代码写在这条注释以下
31   for (var i = 0; i < contacts.length; i++) {
32     if (firstName === contacts[i].firstName) {
33       if (contacts[i].hasOwnProperty(prop)) {
34         return contacts[i][prop];
35       } else {
36         return "No such property";
37       }
38     } else if (i == contacts.length - 1) {
39         return "No such contact";
40     }
41   }
42 // 请把你的代码写在这条注释以上
43 }
44
45 // 你可以修改这一行来测试你的代码
46 console.log(lookUp("Akira", "likes"));
FreeCodeCamp 题目 Profile lookup 思考-LMLPHP

如果有更好的思路,欢迎评论一起讨论!

12-26 06:09