找回密码
 立即注册
搜索
查看: 5|回复: 0

获取容器元素的子节点 转自马黑黑教程专版

[复制链接]

1439

主题

3100

回帖

1万

积分

管理员

积分
12414
发表于 昨天 19:56 | 显示全部楼层 |阅读模式
马黑黑教程专版               https://www.huachaowang.com/foru ... 9&page=1#pid2598647


在网页结构中,HTML容器元素就像“收纳盒”,用于组织和包裹内容,使页面结构更清晰,方便后续的样式和交互处理。通俗一点讲,容器元素就是可以装载其它元素的元素。
最常用的容器元素之一是 <div>,它是块级(block)元素,默认独占一行,没有明显的语义含义,常用于布局和分组。本文以 div 元素为例,简单介绍其内子节点的获取。请看如下示例:
预览<div id="ma" title="点击查看子节点信息">
    <p>这行是一个 p 标签,它是 id="ma" 的 div 容器的标签节点(亦可称元素节点)。</p>
    <div>这是一个 div 节点,内含纯文本。下一个标签节点是一个 img 标签:</div>
    <img src="https://638183.freep.cn/638183/small/dolan.png" alt="">
</div>

<script>
    const ma = document.getElementById('ma');
    ma.onclick = () => {
        let msg = 'id="ma" 的 div 包含如下子标签节点:\n\n';
        const nodes = ma.children;
        [...nodes].forEach((n, k) => msg += `${k+1}. ${n.tagName}\n`);
        alert(msg);
    };
</script>

重点观察 div 标签包裹的子标签,后面的JS仅是交互辅助。从 DIV 的 HTML 代码结构看,我们真真切切看到了三个子标签:p、div和img,它们依次出现在 div 标签之内、被 div 标签所包裹,是 div 的子元素。预览查看效果时点击id="ma"的 div,弹出的信息框会给出所有子标签节点的标签名。
示例中的JS,先获得 id="ma" 的容器元素 ma,ma 的点击事件则通过 children 属性获得其内所有标签(元素)节点,并将其标签名(tagName)取出。
元素的 children 是一个常用的属性或方法,用于获取某个元素的所有直接子元素。它在原生 JavaScript 和 jQuery 中均有实现,主要用于操作 DOM 树。
element.children 即元素子节点属性拿到的是子元素节点(children 是 child 即孩子的复数形式)。但需要注意:容器元素内的子节点不全然是元素节点。以下示例,HTML代码结构和第一例的一样,但在JS中使用元素的 childNodes 即子节点属性获取节点名称(nodeName)——不是第一例的标签名,因为有些节点可能不是元素节点。可以在打开预览页面后点击 div 容器元素,比较弹出的信息和上例弹出信息的区别:
预览<div id="ma" title="点击查看子节点信息">
    <p>这行是一个 p 标签,它是 id="ma" 的 div 容器的标签节点(亦可称元素节点)。</p>
    <div>这是一个 div 节点,内含纯文本。下一个标签节点是一个 img 标签:</div>
    <img src="https://638183.freep.cn/638183/small/dolan.png" alt="">
</div>

<script>
    const ma = document.getElementById('ma');
    ma.onclick = () => {
        let msg = 'id="ma" 的 div 包含如下子节点:\n\n';
        const nodes = ma.childNodes;
        [...nodes].forEach((n, k) => msg += `${k+1}. ${n.nodeName}\n`);
        alert(msg);
    };
</script>

可以看到,节点变多一倍不止,多出来的全是 #text 文本节点,这些 #text 子节点基于示例的 HTML 代码结构,编号1的 #text 是 p 标签和 容器 div 之间的换行符 \n,编号3和编号5的 #text 是上下两个元素标签之间的换行符 \n,编号7的 #text 是 IMG 标签和容器div收尾符号之间的换行符 \n。
childNodes 属性是一个非常重要的 DOM 属性,它返回一个包含指定节点的所有子节点的 NodeList 对象。这个NodeList 是一个实时的集合,意味着如果 DOM 结构发生变化,NodeList 也会相应地更新
最后再给出一组 div 容器的示例,各 div 子节点由于代码结构的不同而不同,值得细细研究、领悟:
预览<style>
    div { margin: 10px auto; width: 600px; border: 1px solid gray; padding: 12px; }
</style>

<div>
    本div只有一个文本节点
</div>

<div><p>本div只有一个p元素节点</p></div>

<div>
    <p>本div有头尾两个文本节点,中间是p元素节点</p>
</div>

<div>
    这里是文本节点1
    <p>这里是p元素节点</p>
    这里是文本节点2
</div>

<div>
    <!-- 这行是注释节点(预览时看不到) -->
    <p>这行p元素节点(上一行是注释行)</p>
</div>

<script>
    const divs = document.querySelectorAll('div');
    divs.forEach(div => {
        div.title = '点击查看节点信息';
        div.onclick = () => {
            let msg = '本 div 包含如下子标签节点:\n\n';
            const nodes = div.childNodes;
            [...nodes].forEach((n, k) => msg += `${k+1}. ${n.nodeName}\n`);
            alert(msg);
        };
    });
</script>

小结:容器元素可以包含很多类型的子节点,通过 element.children 属性可以获取其内的子 element 即子元素节点,而 element.childNodes 属性则返回所有节点——包括文本节点、标签节点和注释节点等。特别注意:当子节点中包含有元素节点且元素节点独占一行时,其上、下均存在换行文本节点(\n)。



您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

协同嘉业科技有限公司 ( 京ICP备2024053108号-1 )

GMT+8, 2026-6-30 03:01 , Processed in 0.079606 second(s), 23 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表