因为循环不起作用?

时间:2016-02-04 00:09:54

标签: javascript loops for-loop let

当我在循环中使用时,它可以正常工作,并且对于循环而言,它不会得到任何东西:( 这是我的代码

'use strict'

var match_table = [
  {'project': 'Laveral', 'template': 'Blade'},
  {'project': 'Ember.js', 'template': 'Handlebars'},
  {'project': 'Meteor', 'template': 'Handlebars'},
];

// count project number by template
var templateMap = new Array();
match_table.forEach(function(listItem){
  var template = listItem['template'];
  if (!templateMap[template]) {
    templateMap[template] = new Object();
  }
  templateMap[template]['name'] = template;
  if (templateMap[template]['count']) {
    templateMap[template]['count']++;
  } else {
    templateMap[template]['count'] = 1;
  }
});

//console.log(templateMap);

// for loop fails
for (let value of templateMap) {
  console.log(value);
}

templateMap.forEach(function(item) {
  console.log(item);
})

也是因为每个人都没有输出任何东西〜?!

2 个答案:

答案 0 :(得分:5)

for-of无法遍历对象(因为它们不能按标准迭代)。

所以你要么必须使用旧的for-in

OR

使用非标准化的Object.entries()

for (const [key, value] of Object.entries(obj)) {
    console.log(key, value);
}
在您的情况下,

templateMap是一个对象,而不是一个数组,因为您将字符串键分配给它(并且JS数组索引在[0; 2^32-1)范围内是数字)。

答案 1 :(得分:1)

template是否为数字?看起来您将要滥用数组作为对象。请尝试将templateMap.push(new Object())附加到数组中。