如何在grandCouncil数组中获取正确的对象变量名称?

时间:2015-11-19 02:38:03

标签: javascript arrays object push

当我在console.log(grandCouncil)时,我最终得到了这个:

[Object, Object, Object]

我想看到的是变量的名称,而不是这样:

[jungleAnimal1, jungleAnimal2, jungleAnimal3]

这是我的代码:

var grandCouncil = [];


var jungleAnimal1 = {
  'type': "frog",
  'collects': ['flys','moths','beetles'],
  'canFly': false
};

var jungleAnimal2 = {
  'type': "jaguar",
  'collects': ['wild pigs','deer','sloths'],
  'canFly': false
};

var jungleAnimal3 = {
  'type': "parrot",
  'collects': ['fruits','bugs','seeds'],
  'canFly': true
};

grandCouncil.push(jungleAnimal1,jungleAnimal2,jungleAnimal3);
console.log(grandCouncil);

2 个答案:

答案 0 :(得分:1)

jungleAnimal1,2和3是对象文字。

当您将它们推入grandCouncil数组时,对这些对象的引用将添加到数组中,但变量名称不会添加。

如果你想在grandCouncil下使用jungleAnimal1,2和3作为属性,那么grandCouncil应该是一个对象,动物可以是属性,如下所示:

grandCouncil = {
    "jungleAnimal1" : { // type, collects, canFly }
    "jungleAnimal2" : ...
    "jungleAnimal3" : ...
}

感谢@zerkms的澄清

答案 1 :(得分:0)

存储在数组中的值是Objects;例如,您可以使用点表示法访问对象的值,因此访问jungleAnimal2的类型只是:

grandCouncil[1].type

你可以

for(var i = 0;i < grandCouncil.length; i++){
    for(animal in grandCouncil[i]){
        console.log(animal);   
    }
}

这只是迭代每个数组元素,它是一个对象,然后迭代这些对象中的每个元素。您可以使用上述点表示法访问特定属性,因此对于console.log所有类型,只需执行animal.type