【前端每日一题】day11

一个盒子(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]); // 输出第三个子元素
相关推荐
cxxcode几秒前
搞懂 JS 异步的底层真相:从 V8 源码看微任务与宏任务
前端
欧阳的棉花糖几秒前
React 小误区:派生值 vs useEffect
前端
马可菠萝4 分钟前
从零开始,用 Tauri + Vue 3 打造轻量级桌面应用
前端
陆枫Larry5 分钟前
JavaScript 字符串处理实战:从 `startsWith` 到链式 `replace` 的避坑指南
前端
天蓝色的鱼鱼21 分钟前
你的项目真的需要SSR吗?还是只是你的简历需要?
前端·架构
颜酱37 分钟前
单调队列:滑动窗口极值问题的最优解(通用模板版)
javascript·后端·算法
恋猫de小郭1 小时前
移动端开发稳了?AI 目前还无法取代客户端开发,小红书的论文告诉你数据
前端·flutter·ai编程
文心快码BaiduComate1 小时前
百度云与光本位签署战略合作:用AI Agent 重构芯片研发流程
前端·人工智能·架构
闲云一鹤2 小时前
nginx 快速入门教程 - 写给前端的你
前端·nginx·前端工程化
QCY2 小时前
「完全理解」1 分钟实现自己的 Coding Agent
前端·agent·claude