DOM(Document Object Model)即文档对象模型。通过DOM树这样一种结构,不仅可以直观的看到HTML的整体结构,还可以利用DOM树的一些属性获取到某个元素的子节点和节点名称等信息。
什么是DOM树?
DOM(Document Object Model)即文档对象模型。通过DOM树这样一种结构,不仅可以直观的看到HTML的整体结构,还可以利用DOM树的一些属性获取到某个元素的子节点和节点名称等信息。
HTML文档结构:
data:image/s3,"s3://crabby-images/4e87e/4e87e4dcd070d0f75573fa04b72c2aa0b966ea04" alt=""
树形结构:
data:image/s3,"s3://crabby-images/f16f8/f16f8f5109bca44ac11205c6c2f67482f1f69e69" alt=""
childNodes和nodeName属性
childNodes属性:获取当前节点的子节点。
<div id="box">
<p>第一个child节点</p>
<h4>第二个child节点</h4>
<div>第三个child节点</div>
</div>
<script>
let box = document.getElementById("box");
let boxChild = box.childNodes;
console.log(boxChild);
</script>
data:image/s3,"s3://crabby-images/eaaba/eaabaddc31bc32b7332440fe20c2f7e4c40b6ef9" alt=""
data:image/s3,"s3://crabby-images/a9f1a/a9f1aa8b2ce85ed5c28c6ae4174d80ee4100278f" alt=""
空格和换行也属于一个节点,用text表示。
for(let i = 1; i < boxChild.length; i += 2)
console.log(boxChild[i]);
data:image/s3,"s3://crabby-images/48f30/48f308a9f871d5de3d379707cce44047e4e05bd8" alt=""
获取1、3、5……奇数节点。
nodeName属性:返回节点名称。
for(let i = 1; i < boxChild.length; i += 2)
console.log(boxChild[i].nodeName);
data:image/s3,"s3://crabby-images/b1ccf/b1ccf34ed2d6bc4d7b18760a1c452fe56de8c6fb" alt=""
appendChild方法
appendChild(node):在子节点最后一位插入新节点,node为新节点的名称。
let newnode = document.createElement("p");
newnode.innerHTML = "新节点";
box.appendChild(newnode);
console.log(boxChild);
data:image/s3,"s3://crabby-images/4d9ba/4d9ba7684cb6c19c561bcdd48ac93359e366a166" alt=""
removeChild方法
removeChild(node):删除指定父级元素的某个子节点。
项目目标:点击删除按钮,依次删除列表中书籍。
data:image/s3,"s3://crabby-images/1855d/1855d4ddc80eddc75047533b472be2841ba8d6ad" alt=""
btn.onclick = function(){
list.removeChild(list.childNodes[1]);
}
parentNode属性
parentNode属性:返回指定节点的父节点。
<div id="box">
<p id="box-item1">第一个child节点</p>
<h4>第二个child节点</h4>
<div>第三个child节点</div>
</div>
<script>
let box_item1 = document.getElementById("box-item1");
console.log(box_item1.parentNode);
</script>
data:image/s3,"s3://crabby-images/6a42e/6a42ef657b0af2b2c6c59c27a55a10af44aaf5c9" alt=""
项目目标:点击叉号删除内容。
data:image/s3,"s3://crabby-images/c037f/c037f59a97aff950a4638952c515a2a860a1ce44" alt=""
x.onclick = function(){
document.body.removeChild(this.parentNode);
}
replaceChild方法
replaceChild(newnode,oldnode)方法:用新节点替换之前的节点。
<div id="box">
<p id="box-item1">第一个child节点</p>
<h4>第二个child节点</h4>
<div id="box-item3">第三个child节点</div>
</div>
<script>
let box_item1 = document.getElementById("box-item1");
console.log(box_item1.parentNode);
let h1 = document.createElement("h1");
h1.innerHTML = "新节点 第三个child节点";
let box_item3 = document.getElementById("box-item3");
let box = document.getElementById("box");
box.replaceChild(h1, box_item3);
</script>
data:image/s3,"s3://crabby-images/707d7/707d7fd0880dd7f3f383c089de0e6fad93cc35ec" alt=""
insertBefore方法
insertBefore可以在已有的子节点前插入一个新的子节点。项目目标:点击按钮,在ul标记子节点的第一位插入包含内容“我的世界”,文字颜色为红色的h4节点。
data:image/s3,"s3://crabby-images/f91bd/f91bdb9b8b41461a15d9e0bd6d3c79b163f7a021" alt=""
let btn = document.getElementById("button");
let game = document.getElementById("game");
btn.onclick = function() {
let newGame = document.createElement("h4");
newGame.innerHTML = "我的世界";
newGame.style.color = "red";
newGame.style.paddingLeft = "40px";
game.insertBefore(newGame, game.firstChild);
}
setAttribute属性
setAttribute属性:添加指定的属性,并为其赋指定的值。
项目目标:点击“变”按钮,将输入框变为按钮。
data:image/s3,"s3://crabby-images/163eb/163eb81a215c91a4230a9b9c25b3980ee799786c" alt=""
let btn = document.getElementById("btn");
let input = document.getElementById("put");
btn.onclick = function() {
input.setAttribute("type", "button");
}