如何循环遍历包含100个具有不同属性的对象的数组,并从每个对象中检索1个属性值
How to loop through an array of 100 objects with different properties and retrieve 1 property value from each?
我有一个包含100个对象的数组,每个对象具有不同的属性。我试图通过数组做一个for循环,从每个对象获得一个特定的属性,并把它推到一个新的数组。我试过:
for (var item in response.data) {
main.allUsers.push(item);
}
当我console.log(main.allUsers);我得到一个数组看起来像("0"、"1"、"2"、"3"、"4"……] .
当遍历对象属性时,for...in
循环的左侧是一个字符串,表示当前对象的属性名称。所以,你必须使用符号object['property']来获得那个属性的对应值。您应该使用:
main.allUsers.push(response.data[item]);
虽然,看起来你的response.data
是一个数组,而不是一个对象,所以,你不应该使用for...in
,因为它被设计为通过对象属性循环。
当循环通过数组时,您应该使用常规的for
循环,或者您可以使用Array.prototype.forEach
循环,它将迭代类似于您尝试使用for...in
的方式。当ES6被完全支持时,你将能够使用for...of
循环,这与你正在尝试的类似:
for (var i = 0; i < response.data.length; i++) {
var item = response.data[i];
main.allUsers.push(item);
}
// or
response.data.forEach(function(item, i) {
main.allUsers.push(item);
}
// and in the future (it already works in Firefox, if you wanna give a try)
for (var item of response.data) {
main.allUsers.push(item);
}
回答你的评论,你可以使用:
response.data.forEach(function(item) {
main.allUsers.push(item.DisplayName);
});
// or
for (var i = 0; i < response.data.length; i++) {
main.allUsers.push(response.data[i].DisplayName);
}
// or if you don't have any items inside main.allUsers yet
main.allUsers = response.data.map(function(item) { return item.DisplayName; });
您还可以使用javascript执行以下操作。Jsfiddle
var arrayOfObjects = [
{name: "myName1",
age: 12
},
{surname: "mySurname2",
age: 26
}
//98 more...
];
var myData = [];
for(var i = 0; i < arrayOfObjects.length; i++){ //iterate array of objects
for(var key in arrayOfObjects[i]){ //iterate each object key
if(arrayOfObjects[i].hasOwnProperty(key) && key == "age"){
//make sure its the key you want
myData.push(arrayOfObjects[i].age);
}
}
}
console.log(myData);
要获取数组中的每个对象,必须使用
for(var i=0; i < response.data.length; i++){
var obj = response.data[i];
}
现在要获取对象的每个属性,
for(var i=0; i < response.data.length; i++){
var obj = response.data[i];
for (property in obj){
console.log(property);
}
}
不要对数组https://developer.mozilla.org/ru/docs/Web/JavaScript/Reference/Statements/for...in#Array_iteration_and_for...in使用for..in
。使用forEach
,或标准for
,或map
。如:
var _len = response.data.length;
for (var i = 0; i < _len; i++) {
main.allUsers.push(response.data[i]);
}
相关文章:
- 为什么我可以在Array属性对象中找到Javascript Array for Each方法
- 使用onclick调用属性对象函数
- 嵌套为..in 循环,列出多维对象的属性(对象)
- 动态属性对象 - JSON
- 在不使用隔离范围angularjs自定义指令的情况下获取属性对象
- 通过属性传递属性/对象.Javascript
- Javascript:属性/对象的类型
- 访问JSON中的属性(对象)
- 属性对象Javascript不是用Jquery Deferred设置的
- 无法读取属性'#<对象>'未定义的获取错误
- Twitter中多属性对象的子字符串匹配
- 无法设置'data'属性'对象'标记.(只IE8)
- 更新数据属性对象属性值
- 将属性对象的选定对象从原型推入数组
- 将单个属性对象字面量的数组转换为仅包含其值的数组的最佳方法
- 寻找一种更简单的方法来检查是否多个属性&对象中的方法是未定义的
- 主干模型:带有get方法的空属性,但在属性对象中
- 如何赋值给"text"someText"属性对象在动能js
- Angularjs的数据绑定与数据属性对象
- 如何将一个嵌套的javascript对象转换为只有一级属性对象