如何使用appendChild添加多个div?

svt*_*skl 40 javascript appendchild

我正在尝试使用javascript创建一个棋盘并用它创建64个div.
问题是,它只创建了第一个div.
这是代码:

div {
    width: 50px;
    height: 50px;

    display: block;
    position: relative;
    float: left;
}

<script type="text/javascript">
    window.onload=function()
    {
        var i=0;
        var j=0;
        var d=document.createElement("div");

        for (i=1; i<=8; i++)
        {
            for (j=1; j<=8; j++)
            {
                if ((i%2!=0 && j%2==0)||(i%2==0 && j%2!=0))
                {
                    document.body.appendChild(d);
                    d.className="black";
                }
                else
                {
                    document.body.appendChild(d);
                    d.className="white";
                }
            }
        }
    }
</script>
Run Code Online (Sandbox Code Playgroud)

Ren*_*non 63

正如tj-crowder所指出的那样,OP的代码只创建了一个div.但是,对于谷歌来说,有一种方法可以appendChild在DOM中添加多个元素:创建一个documentFragment.

function createDiv(text) {
  var div = document.createElement("div");
  div.appendChild(document.createTextNode(text));
  return div;
}

var divs = [
  createDiv("foo"),
  createDiv("bar"),
  createDiv("baz")
];

var docFrag = document.createDocumentFragment();
for(var i = 0; i < divs.length; i++) {
  docFrag.appendChild(divs[i]); // Note that this does NOT go to the DOM
}

document.body.appendChild(docFrag); // Appends all divs at once
Run Code Online (Sandbox Code Playgroud)

  • 添加多个元素时,应始终使用`documentFragment`.`documentFragment`充当临时区域,您可以在其中重复添加元素,最后将其添加到`DOM`.反复向`DOM`添加元素将导致整个文档重排.见:http://ejohn.org/blog/dom-documentfragments/ (7认同)

T.J*_*der 27

问题是,它只创建了第一个div.

是的,因为你只创造了一个div.如果要创建多个,则必须createElement多次调用.移动你的

d=document.createElement("div");
Run Code Online (Sandbox Code Playgroud)

线所述j环.

如果您调用appendChild传入已经在DOM中的元素,则会移动它,而不是复制它.

window.onload=function()
    {
        var i=0;
        var j=0;

        for (i=1; i<=8; i++)
        {
            for (j=1; j<=8; j++)
            {
                if ((i%2!=0 && j%2==0)||(i%2==0 && j%2!=0))
                {
                    var d=document.createElement("div");
                    document.body.appendChild(d);
                    d.className="black";
                }
                else
                {
                    var d=document.createElement("div");
                    document.body.appendChild(d);
                    d.className="white";
                }
            }
        }
    }
Run Code Online (Sandbox Code Playgroud)

  • 请注意,每次调用 `appendChild()` 时,这种方法都会导致页面重排(计算元素的位置和几何图形)。使用`documentFragment`(见下文)批量追加子项。 (2认同)

mag*_*ker 12

虽然TJ Crowder编写的内容很好,我建议使用documentFragment将其重写为下面的代码,就像Renato Zannon建议的那样.这样你只会写一次DOM.

    window.onload = function() {
        var count = 5,
            div,
            board = document.getElementById('board'),
            fragment = document.createDocumentFragment();
        
        // rows
        for (var i = 0; i < count; ++i) { 

            // columns
            for (var j = 0; j < count; ++j) { 
                div = document.createElement('div');
                div.className = (i % 2 != 0 && j % 2 == 0) || (i % 2 == 0 && j % 2 != 0) ? 'black' : 'white';
                fragment.appendChild(div);
            }
        }
        
        board.appendChild(fragment);
    };
Run Code Online (Sandbox Code Playgroud)
#board {
  background-color: #ccc;
  height: 510px;
  padding: 1px;
  width: 510px;
}

.black,
.white {
    float: left;
    height: 100px;
    margin: 1px;
    width: 100px;
}

.black {
  background-color: #333;
}

.white {
  background-color: #efefef;
}
Run Code Online (Sandbox Code Playgroud)
<div id="board"></div>
Run Code Online (Sandbox Code Playgroud)