当前位置: 移动技术网 > IT编程>开发语言>JavaScript > JS遍历DOM文档树的方法实例详解

JS遍历DOM文档树的方法实例详解

2018年04月10日  | 移动技术网IT编程  | 我要评论
本文实例讲述了js遍历dom文档树的方法。分享给大家供大家参考,具体如下: 一 介绍 遍历文档树通过使用parentnode属性、firstchild属性、lastch

本文实例讲述了js遍历dom文档树的方法。分享给大家供大家参考,具体如下:

一 介绍

遍历文档树通过使用parentnode属性、firstchild属性、lastchild属性、previoussibling属性和nextsibling属性来实现。

1、parentnode属性

该属性返回当前节点的父节点。

[pnode=]obj.parentnode

pnode:该参数用来存储父节点,如果不存在父节点将返回“null”。

2、firstchild属性

该属性返回当前节点的第一个子节点。

[cnode=]obj.firstchild

cnode:该参数用来存储第一个子节点,如果不存在将返回“null”。

3、lastchild属性

该属性返回当前节点的最后一个子节点。

[cnode=]obj.lastchild

cnode:该参数用来存储最后一个子节点,如果不存在将返回“null”。

4、previoussibling属性

该属性返回当前节点的前一个兄弟节点。

[snode=]obj.previoussibling

snode:该参数用来存储前一个兄弟节点,如果不存在将返回“null”。

5、nextsibling属性

该属性返回当前节点的后一个兄弟节点。

[snode=]obj.nextsibling

snode:该参数用来存储后一个兄弟节点,如果不存在将返回“null”。

二 应用

遍历文档树,在页面中,通过相应的按钮可以查找到文档的各个节点的名称、类型和节点值。

三 代码

<head>
<title>遍历文档树</title>
</head>
<body >
<h3 id="h1">三号标题</h3>
<b>加粗内容</b>
<form name="frm" action="#" method="get">
节点名称:<input type="text" id="na"/><br />
节点类型:<input type="text" id="ty"/><br />
节点的值:<input type="text" id="va"/><br />
<input type="button" value="父节点" onclick="txt=nodes(txt,'parent');"/>
<input type="button" value="第一个子节点" onclick="txt=nodes(txt,'firstchild');"/>
<input type="button" value="最后一个子节点" onclick="txt=nodes(txt,'lastchild');"/><br>
<input name="button" type="button" onclick="txt=nodes(txt,'previoussibling');" value="前一个兄弟节点"/>
<input type="button" value="最后一个兄弟节点" onclick="txt=nodes(txt,'nextsibling');"/>
<input type="button" value="返回根节点" onclick="txt=document.documentelement;txtupdate(txt);"/>
</form>
<script language="javascript">
<!--
function txtupdate(txt)
{
 window.document.frm.na.value=txt.nodename;
 window.document.frm.ty.value=txt.nodetype;
 window.document.frm.va.value=txt.nodevalue;
}
function nodes(txt,nodename)
{
switch(nodename)
{
case"previoussibling":
if(txt.previoussibling)
{
 txt=txt.previoussibling;
}
else
 alert("无兄弟节点");
break;
case"nextsibling":
if(txt.nextsibling)
{
 txt=txt.nextsibling;
}
else
 alert("无兄弟节点");
break;
case"parent":
if(txt.parentnode)
{
 txt=txt.parentnode;
}
else
 alert("无父节点");
break;
case"firstchild":
if(txt.haschildnodes())
{
 txt=txt.firstchild;
}
else
 alert("无子节点");
break;
case"lastchild":
if(txt.haschildnodes())
{
 txt=txt.lastchild;
}
else
 alert("无子节点")
break;
}
 txtupdate(txt);
return txt;
}
var txt=document.documentelement;
 txtupdate(txt);
-->
</script>
</body>

四 运行结果

更多关于javascript相关内容感兴趣的读者可查看本站专题:《javascript操作dom技巧总结》、《javascript错误与调试技巧总结》、《javascript数据结构与算法技巧总结》、《javascript遍历算法与技巧总结》及《javascript数学运算用法总结

希望本文所述对大家javascript程序设计有所帮助。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网