我想循环遍历数组中包含的对象,并更改每个对象的属性。如果我这样做:

for (var j = 0; j < myArray.length; j++){

console.log(myArray[j]);

}

控制台应该显示数组中的每个对象,对吧?但实际上它只显示第一个对象。如果我在循环外对数组进行console日志记录,所有的对象都会出现,所以里面肯定有更多的对象。

不管怎样,这是下一个问题。我如何访问,例如Object1。X在数组中,使用循环?

for (var j = 0; j < myArray.length; j++){

console.log(myArray[j.x]);

}

这将返回“undefined”。循环外的控制台日志再次告诉我,所有对象都有“x”的值。如何在循环中访问这些属性?

其他地方建议我为每个属性使用单独的数组,但我想先确保我已经用尽了这个方法。

谢谢你!


当前回答

myArray [j。X]逻辑上是不正确的。

使用(myArray [j]。x);而不是

for (var j = 0; j < myArray.length; j++){
  console.log(myArray[j].x);
}

其他回答

Var c = { myProperty:( {name: 'this'}, {name: 'can'}, {name: 'get'}, {name: 'crazy'} ] }; c.myProperty.forEach(函数(myProperty_element) { var x = myProperty_element.name; Console.log('成员的名称是:' + x); })

这是我成功的方法之一。

这里有一个例子,告诉你如何做到这一点:)

Var学生= [{ 名称:“迈克”, 声道:“跟踪”, 成就:23日, 点:400 }, { 名称:“詹姆斯”, 声道:“跟踪”, 成就:2 点:21日 }, ] students.forEach myFunction (); 函数myFunction(item, index) { For (var key in item) { console.log(项目(例子)) } }

myArray [j。X]逻辑上是不正确的。

使用(myArray [j]。x);而不是

for (var j = 0; j < myArray.length; j++){
  console.log(myArray[j].x);
}

公认的答案使用正常函数。因此,在forEach上发布相同的代码,并使用箭头函数进行轻微修改

  yourArray.forEach(arrayItem => {
      var x = arrayItem.prop1 + 2;
      console.log(x);
  });

同样是美元。每个你可以使用箭头函数如下

 $.each(array, (item, index) => {
       console.log(index, item);
 });

下面是另一种遍历对象数组的方法(您需要在文档中包含jQuery库)。

$.each(array, function(element) {
  // do some operations with each element... 
});