每次循环增加3后,关闭并打开另一个div

时间:2013-09-28 20:27:16

标签: javascript css html

我有一个数组。我正在循环。首先我需要的是,当首先运行循环时,它应该已经打开一个div并向其添加文本。接下来我想要一个循环运行3次然后关闭前一个div并打开一个新的div。

代码:

var counter = 0;
for (var i = 0; i < tag_array.length; i++) {
    counter++;
    if (counter == 3) {
        counter = 0;
        document.write("</div>");
        document.write("<div class='span6'>");
    } else {
        document.write("<div class='span6'>");
    }
    document.write("<div class='tag'>" + toTitleCase(tag_array[i]) + "</div>");
}

以上代码无效。我不知道为什么。请解释一下我做错了什么以及如何解决?

2 个答案:

答案 0 :(得分:3)

  

首先运行循环时,它应该已经打开一个div并向其添加文本。接下来我想要一个循环运行3次然后关闭前一个div并打开一个新的div。

你做错的原因是因为else { document.write("<div class='span6'>");}即使在计数器为2时也会导致document.write

所以你应该把它改成else if(counter == 1)

var counter = 0;
for (var i = 0; i < tag_array.length; i++) {
    //this line indicates that the counter will only be either 1,2,3 when it enters the if statement
    counter++;
    if(counter == 3){
        counter = 0;
        document.write("</div>");
    }else if(counter == 1){
        document.write("<div class='span6'>");
    }
    document.write("<div class='tag'>" + toTitleCase(tag_array[i]) + "</div>");
}

为了让它看起来不那么令人困惑,你可以将if语句更改为switch语句,在switch语句中使用counter++;并将for语句转换为while语句:

var counter = 0;
var i = 0;
var length = tag_array.length;
while (i <length) {
    switch(counter){
        case 2:
        document.write("</div>");
        //when counter reaches 2, set it back to 0 and leave the switch statement;
        counter = 0;
        break;
        case 0:
        document.write("<div class='span6'>");
        case 1:
        //counter++ will only be triggered when counter is 1 or 0;
        counter++;
    }
    document.write("<div class='tag'>" + toTitleCase(tag_array[i]) + "</div>");
    i++;
}

或者如果您想提高效率,可以使用以下代码。 (灵感来自frenchie's answer。我更正了他对正常工作的答案。如果您想通过以下代码提出或接受此答案,请提前投票或接受his

var a = '<div class="span6">';

var length = tag_array.length;

for (var i = 0; i < length; i++) {


  a += '<div class="tag">' + toTitleCase(tag_array[i]) + '</div>';

 if (i % 3 == 2) {

      a += '</div><div class="span6">';
  }

}

a += '</div>';

document.write(a);

答案 1 :(得分:1)

您正在打开另一个span而不是每次迭代都关闭它,所以您应该从循环中取出第一个跨度。

这应该有效,我还在循环结束时添加了另一个</div>

var counter = 0;
document.write("<div class='span6'>");
for (i = 0; i < tag_array.length; i++) {
    if (counter === 3) {
        counter = 0;
        document.write("</div>");
        document.write("<div class='span6'>");
    }

    document.write("<div class='tag'>" + toTitleCase(tag_array[i]) + "</div>");
    counter++;
    if (i === tag_array.length - 1) {
        document.write("</div>")
    }
}