当我在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);
答案 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
。