for 循环 return 终止循环 注意遍历的位子。

①题目

我们有一个对象数组,里面存储着通讯录。

函数 lookUp 有两个预定义参数:firstName值和prop属性 。

函数将会检查通讯录中是否存在一个与传入的 firstName 相同的联系人。如果存在,那么还需要检查对应的联系人中是否存在 prop属性。

如果它们都存在,函数返回prop属性对应的值。

如果firstName 值不存在,返回 "No such contact"

如果prop 属性不存在,返回 "No such property"

 

 

 

 

这个查询通讯录的功能,return会终止循环,所以要注意判断的位子。

如果f用return代替那么for循环一次就终止了循环返回结果。那么显然这样是不对的,必须要循环所有的元素,才能返回结果。

而其他的只需符合一次就可以终止,后面的不需要返回,也符合要求。

//初始化变量
var 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 lookUp(firstName, prop){
// 请把你的代码写在这条注释以下
  
  var f = "";
  
 for(var i = 0;i<contacts.length;i++){
        
   var b = contacts[i].firstName; // 所有firstName的值
   var x = contacts[i].hasOwnProperty(prop);//判断每一个对象有没有prop变量的属性
     
  if   (firstName == b && x ===true){
       return contacts[i][prop];
 
   }
   else if (firstName == b && x===false){
      return "No such property";
     
   }
  
   else if(firstName !== b ){
     f = "No such contact";               //这里不能用return是因为参数不相干  1.  不管怎样,他在第一个物体上停下来。当函数返回时,所有内容都在内部停止。函数返回时循环停止。  2.当返回到循环的内部时,循环将立即终止——所以for循环只能达到一次迭代。  3.但要返回“没有这样的联系”,你必须首先搜索所有联系人。          
   }

   
 }
  
return f;
  

  
  
// 请把你的代码写在这条注释以上
}

// 你可以修改这一行来测试你的代码
lookUp("Akira","likes");

  

转载于:https://www.cnblogs.com/zwl16/p/7984151.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值