数组对象的属性名和属性值的提取

<span style="font-family: 'Microsoft YaHei'; line-height: 18.1818px; white-space: pre-line; background-color: rgb(255, 255, 255);">有一个对象数组,里面存储着通讯录。</span>

函数 lookUp 有两个参数: firstNameprop

函数将会检查通讯录是否存在 firstName值 和 prop 属性。

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

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

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

//Setup
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){

  for (var i in contacts)
  {if (contacts[i].firstName === firstName && prop in contacts[i])
     return contacts[i][prop];}
  for ( i in contacts)
  {  if (prop in contacts[i] ===false)
     return  "No such property";  
  }
  for ( i in contacts)
  {  if (contacts[i].firstName !== firstName)
     return "No such contact";}
  
}

// Change these values to test your function
lookUp("Akira", "address");

关于属性名和属性值:

在这个案例中,contacts[i].firstName 指的是属性值,prop in contacts[i]提取的是属性名,由于是嵌套数组形式({[属性名:值],[属性名:值]},所以需要添加i,遍历i组的属性名和属性值。


以下方法转自某网友的代码,使用hasOwnProperty:是用来判断一个对象是否有你给出名称的属性或对象。不过需要注意的是,此方法无法检查该对象的原型链中是否具有该属性,该属性必须是对象本身的一个成员。

<span style="font-family:Microsoft YaHei;">for(var i=0;i<contacts.length;i++){
if(contacts[i].firstName==firstName){
if(contacts[i].hasOwnProperty(prop)){
return contacts[i][prop];
}
else{return "No such property";}
}
}return "No such contact";</span>



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值