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)
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)
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)