childNodes和nodeType

本文通过一个具体的HTML页面示例介绍了如何使用JavaScript来遍历和操作DOM树中的元素节点,重点展示了如何区分文本节点和元素节点,并对特定元素进行样式修改。

注意li里面的span和h3标签不是ul的子节点。

<!DOCTYPE html>

<html>
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript">
window.onload=function(){
var oUl=document.getElementById('ul1');
//alert(oUl.childNodes.length);  //5个,因为childNodes包括文本节点和元素节点
//alert(oUl.children.length);  //2个,因为children只包括元素节点

for(var i=0;i<oUl.childNodes.length;i++){
//alert(oUl.childNodes[i].nodeType);    //文本节点值是3,元素节点值是1
//alert(oUl.children[i].nodeType);       //children挺好用的
//oUl.children[i].style.background='yellowgreen';
if(oUl.childNodes[i].nodeType==1){
oUl.childNodes[i].style.background='red';
}
}
}
</script>
</head>
<body>
<ul id="ul1">
sdeee

<li>slkk

<span>sssssiii</span>

<h3>hhhhh</h3>

</li>asdwaw

<li>qqawww</li>dddlllllaa
</ul>
</body>
</html>
### `childNodes` 的使用及作用 `childNodes` 是 JavaScript 中用于获取指定元素所有子节点的属性,它返回一个 `NodeList` 对象,该对象是一个类数组集合,包含了指定元素的所有子节点,这些子节点可以是元素节点、文本节点、注释节点等。 ### 使用方法示例 ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> </head> <body> <ul id="ul"> <li>1</li> <li>2</li> <li>3</li> </ul> <script> var ul = document.getElementById("ul"); var child = ul.childNodes; console.log(child); </script> </body> </html> ``` 上述代码中,通过 `document.getElementById("ul")` 获取到 `ul` 元素,然后使用 `childNodes` 属性获取其所有子节点,并将结果存储在 `child` 变量中,最后将其打印到控制台。需要注意的是,在一些浏览器中,换行符、空格等也会被当作文本节点,所以获取的 `childNodes` 可能会包含这些空白文本节点 [^1][^2]。 ### 使用 `childNodes` 获取文本子节点 可以通过遍历 `childNodes` 列表,利用 `nodeType` 属性来判断节点是否为文本节点(`Node.TEXT_NODE` 的值为 3),示例如下: ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> </head> <body> <div id="box">测试Div倾斜结尾</div> <script> var box = document.getElementById('box'); var childNodes = box.childNodes; for (var i = 0; i < childNodes.length; i++) { if (childNodes[i].nodeType === Node.TEXT_NODE) { console.log(childNodes[i].nodeValue); } } </script> </body> </html> ``` 在这个例子中,首先获取 `box` 元素,然后使用 `childNodes` 获取其所有子节点。接着遍历子节点列表,通过 `nodeType` 判断每个节点是否为文本节点,如果是,则打印其 `nodeValue`(即文本内容) [^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值