数组对象的属性名和属性值的提取
2016-08-01 18:17
459 查看
<span style="font-family: 'Microsoft YaHei'; line-height: 18.1818px; white-space: pre-line; background-color: rgb(255, 255, 255);">有一个对象数组,里面存储着通讯录。</span>
函数
函数将会检查通讯录是否存在
如果它们都存在,函数返回
如果
如果
关于属性名和属性值:
在这个案例中,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>
函数
lookUp有两个参数:
firstName和
prop。
函数将会检查通讯录是否存在
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 functionlookUp("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>
相关文章推荐
- 要求从用户输入的多行文本中提取学生的姓名、学号及登录日期,并封装到 Student 类中作为类的私有属性。创建一个 Student 类型的对象数组,对学号进行 升序排序并输出
- JSON对象属性名与属性值的提取
- 要求从用户输入的多行文本中提取学生的姓名、学号及登录日期,并封装到 Student 类中作为类的私有属性。创建一个Student类型的对象数组,对学号进行 升序排序并输出。
- json:创建一个对象,其它一个属性是数组;创建一个对象,使用function作为属性值
- Spring框架xml配置文件 复杂类型属性注入——数组 list map properties DI dependency injection 依赖注入——属性值的注入依赖于建立的对象(堆空间)
- 根据动态配置来提交对象属性值和设置属性值实现
- 类加载器及反射机制(二)-根据对象属性读取属性值
- 将属性的XML解析成对象数组列表
- 根据属性名称 获取对象的属性值
- Javascript数组对象的方法和属性
- 对象无length属性时IE6/7中无法将其转换成伪数组(ArrayLike)
- JavaScript数组对象操作方法属性全集合
- Javascript数组对象的方法和属性
- 对象无length属性时IE6/IE7中无法将其转换成伪数组(ArrayLike)
- js中将具有数字属性名的对象转换为数组
- js中将具有数字属性名的对象转换为数组
- 使对象可以像数组一样进行foreach循环,要求属性必须是私有
- Javascript数组对象的方法和属性
- 对象数组根据某属性列的灵活排序 (续)
- JavaScript数组对象操作方法属性全集合