一个盒子(DIV)里有若干个小盒子,每个小盒子里还可能有多个小盒子
多层盒子结构。每个盒子都有一个唯一的id和 name 属性。现在给出一个盒子的 id
请找到这个盒子并打开,输出这个盒子内部所有小盒子的id和 name,并继续打开这些小盒子输出id和 name(由外到内逐层打印)
javascript
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Open Div</title>
</head>
<body>
<div id="box1" name="box1">
<div id="box2" name="box2">
<div id="box4" name="box4"></div>
</div>
<div id="box3" name="box3">
<div id="box5" name="box5">
<div id="box7" name="box7"></div>
</div>
<div id="box6" name="box6"></div>
</div>
</div>
<script>
function findAndOpenBox(targetId) {
const box = document.getElementById(targetId);
if (!box) {
console.log("盒子未找到");
return;
}
openBox(box);
}
function openBox(box) {
console.log("盒子ID:", box.id, "盒子名称:", box.getAttribute("name"));
const childBoxes = box.children;
for (let i = 0; i < childBoxes.length; i++) {
const childBox = childBoxes[i];
console.log("子盒子ID:", childBox.id, "子盒子名称:", childBox.getAttribute("name"));
openBox(childBox);
}
}
// 指定目标盒子的 ID
const targetBoxId = "box1";
// 开始查找并打开盒子
findAndOpenBox(targetBoxId);
</script>
</body>
</html>
先通过document.getElementById()方法获得指定id 的div DOM元素,然后向下递归调用开盒子方法。
getAttribute() 是一个用于获取元素属性值的方法。它允许你通过属性名来获取指定元素的属性值。
children属性可以返回一个类似数组的对象,其中包含了所有子元素。
such as
javascript
<div id="parent">
<div id="child1"></div>
<div id="child2"></div>
<div id="child3"></div>
</div>
javascript
const parent = document.getElementById("parent");
const childElements = parent.children;
console.log(childElements.length); // 输出 3,因为有三个子元素
console.log(childElements[0]); // 输出第一个子元素
console.log(childElements[1]); // 输出第二个子元素
console.log(childElements[2]); // 输出第三个子元素