循环通过具有javascript数组的json对象

时间:2013-06-26 09:37:44

标签: javascript arrays json for-loop

我想用JS输出

<ul>
  <li>title1
    <ul>
      <li>image1</li>
      <li>image2</li>
      <li>image3</li>
   </ul>
  </li>
  <li>title2
    <ul>
      <li>image1</li>
      <li>image2</li>
      <li>image3</li>
   </ul>
  </li>

...and so forth...

</ul>

JSON:

var data = [
    {
        title: "title1", 
        image:["image1", "image2", "image3"]
    },
    {
        title: "title2", 
        image:["image1", "image2", "image3"]
    },
    {
        title: "title3", 
        image:["image1", "image2", "image3"]
    },
    {
        title: "title4", 
        image:["image1", "image2", "image3"]
    }
];

我的JS

for(var i=0; i < data.length; i++) {
  var item = data[i];
  var obj = {
      title:item.title,
      image:item.image
  };
  var theimages;
  var html = '';

    for(j=0; j < item.image.length; j++) {
         theimages = '<li>' + item.image[j] + '</li>'; 
    }

html += '<li>' + item.title + '<ul>';
html += theimages;
html += '</ul></li>';
} 
console.log(html);

有人可以解释如何获取内部for loop的值并将其与外部for loop合并,以便我最终得到输出I'我试图实现。目前我最终得到了这个:

<li>title4
  <ul>
    <li>image3</li>
  </ul>
</li>

2 个答案:

答案 0 :(得分:4)

您只需将其附加到字符串,而不是一次又一次地重新分配变量:

var theimages;
var html = '<ul>';
for(var i=0; i < data.length; i++) {
  var item = data[i];
  var obj = {
      title:item.title,
      image:item.image
  };


for(j=0; j < item.image.length; j++) {
         theimages += '<li>' + item.image[j] + '</li>'; 
    }

html += '<li>' + item.title + '<ul>';
html += theimages;
html += '</ul></li>';
}  
html += '</ul>';
console.log(html);

答案 1 :(得分:0)

问题是你在外部for循环的每次迭代中都覆盖 html 变量。

如果在循环之前声明此变量,则会得到正确的结果。此外,您不希望每次都覆盖 theimages 变量,而是将新部分附加到其中。

var html = '';
for(var i=0; i < data.length; i++) {
  var item = data[i];
  var theimages = '';
  for(j=0; j < item.image.length; j++) {
    theimages += '<li>' + item.image[j] + '</li>'; 
  }

  html += '<li>' + item.title + '<ul>';
  html += theimages;
  html += '</ul></li>';
} 
console.log(html);

此外,我已删除了你的obj变量,因为你还没有使用它。

如果您构建字符串,只需使用此模式:     var myString =''     for(item ...){       myString + = item     } 首先初始化字符串,然后追加。