HtmlDOM树的结构和访问

你对Html DOM树的概念是否了解,这里和大家分享一下,DOM(DocumentObjectModel)解析器将XML文档一次性解析,生成一个位于内存中的对象树用以描述该文档。

创新互联主营大关网站建设的网络公司,主营网站建设方案,App定制开发,大关h5微信小程序开发搭建,大关网站营销推广欢迎大关等地区企业咨询

Html DOM树

1.Html DOM树

所有类型的XML解析器都要求处理对象是“格式良好”的XML文档,有些还能根据DTD或XMLSchema进行有效性验证,DOM(DocumentObjectModel)解析器将XML文档一次性解析,生成一个位于内存中的对象树用以描述该文档。

DOM是一种与平台和语言无关的接口,它允许程序和脚本动态访问和修改文档的内容、结构和类型。它定义了一系列的对象和方法对Html DOM树的节点进行各种随机操作:

◆Document对象:作为树的最高节点,Document对象是对整个文档进行操作的入口。

◆Element和Attr对象:这些节点对象都是文档某一部分的映射,节点的定级层次恰好反映了文档的结构。

◆Text对象:作为Element和Attr对象的子节点,Text对象表达了元素或属性的文本内容。Text节点不再包含任何子节点。

◆集合索引:DOM提供了几种集合索引方式,可以对节点按指定方式进行遍历。索引参数都是从0开始记数的。

Html DOM树中的所有节点都是从Node对象继承而来的。Node对象定义了一些最基本的属性和方法,利用这些方法可以实现对树的遍历,同时,根据属性还可以得知节点的名称、取值并判断其类型。
利用DOM,开发人员可以动态地创建XML、遍历文档、增加/删除/修改文档内容。DOM提供的API与编程语言无关,所以对一些DOM标准中没有明确定义的接口,不同解析器的实现方法也可能有所差别。为方便描述,本文的举例均采用MSXMLDOM方案并用VBScript编写代码。

2.Html DOM树的结构

Document对象建立之后,就可以与XML文档或数据岛联系在一起。数据岛的加载方法是将数据岛ID赋给Document对象:

 
 
 
  1. Setdoc=dsoDetails.XMLDocument

加载文档大体上分为三步:

1.使用CreateObject方法创建分析器实例;

2.设置async属性为False,禁止异步加载,这样当文档加载完毕,控制权才会返回给调用进程,如果想获取文档加载状态,可以读取readyState属性值;

3.使用load方法加载指定文档。

 
 
 
  1. Setdoc=CreateObject(“Microsoft.XMLDOM”)
  2. doc.async=False
  3. doc.load“Books.xml”

XMLDOM还提供了一种loadXML的方法可以把XML字符串加载到Html DOM树中,使用时只要把XML字符串直接作为该方法的参数即可。#p#

3.Html DOM树的访问

在文档加载完毕之后就可以使用documentElement属性访问根元素:

 
 
 
  1. SetrootNode=doc.documentElement

一旦建立了对Html DOM树中某个节点(例如根节点)的引用,就可以根据节点间的等级关系调用适当的方法进行遍历。
下面以books.xml为例说明各种方法的使用:

 
 
 
  1. TheGourmetMicrowave
  2. 9.95
  3. CharlotteM.Cooper
  4. ShelleyB.Burke
  5. ReginaP.Murphy
  6. Sushi,Anyone?
  7. 14.99
  8. StraightTalkAboutComputers
  9. 19.99
  10. LarsPeterson

 建立对第二个元素的引用:

 
 
 
  1. SettheNode=dsoBooks.XMLDocument.
  2. documentElement.childNodes(1)

◆根节点:theNode.ownerDocument返回Document节点,指向XML文档本身;
◆兄弟节点:theNode.previousSibling返回第1个元素,theNode.nextSibling返回第3个元素;
◆父节点:theNode.parentNode返回元素;
◆子节点:theNode.firstChild返回元素,theNode.lastChild返回<price>元素,theNode.childNodes返回子节点集合,包括Sushi下面的所有元素。节点记数从0开始,即theNode.childNodes(0)的结果与theNode.firstChild的结果是一样的。</p><p><strong>获得节点的引用后,就可以读取节点的相关信息:</strong></p><p>◆节点类型:theNode.nodeType,本例为1,Document对象类型为9,元素类型为1,属性类型为2;<br /> ◆节点名称:theNode.nodeName,本例为book;<br /> ◆节点值:theNode.nodeValue,本例为null,对于Attr节点,返回的是属性值,而对于Element节点,返回的是null。</p><p>在MSXML中,对Node对象还提供了一些额外的方法和属性:</p><p>◆nodeTypeString:用字符串的方式显示节点类型,如theNode.nodeTypeString的结果是“element”;<br /> ◆text:显示当前节点及其所有子节点的文本内容;<br /> ◆xml:获取XML文档数据,通常是从根元素开始的所有内容。#p#</p><p><strong>4.XML格式的动态转换</strong></p><p>通过学习XSL,我们已经能够使用样式单对XML文档进行转换。但这种过程是静态的,即在编写代码时,已经指定了作用在XML上的XSL文件,在程序运行过程中不能再做改变。而利用DOM,我们能够实现XML格式的动态转换,即在程序运行时,将XSL载入并对XML文档进行转换。</p><p>把XSL载入DOM对象的步骤基本上与XML文档的载入过程是一样的(XSL本身就是XML文档):</p><pre> <ol> <li>Setstylesheet=CreateObject(“Microsoft.XMLDOM”) </li> <li>stylesheet.async=False</li> <li>stylesheet.load“TransformDetails.xsl”</li> </ol></pre><p>DOM提供了两个函数进行这种转换,作用对象可以是树中任何节点。这样就可以实现对Html DOM树的任意的部分进行格式转换。<br /> ◆transformNodeToObject方法:该方法需要两个参数,第一个参数指向XSL文件,第二个参数存放转换后的XML数据的节点。例如:</p><pre> <ol> <li>SettargetNode=CreateObject(“Microsoft.XMLDOM”) </li> <li>srcNode.transformNodeToObjectstylesheet,targetNode </li> <li></li> </ol></pre><p>◆transformNode方法:该方法只需要一个参数指明XSL文件。如下例是将源节点转换为一个字符串变量str:<br /></p><pre> <ol> <li>str=srcNode.transformNode(stylesheet) </li> <li></li> </ol></pre> <br> 文章名称:HtmlDOM树的结构和访问 <br> 网址分享:<a href="http://www.gxwzsj.com/article/djjchgo.html">http://www.gxwzsj.com/article/djjchgo.html</a> </div> <div class="view-qrocde cl"> <div class="m z"><img src="/Public/Home/images/ew.jpg"/></div> <div class="text"> <h6>扫二维码与项目经理沟通</h6> <p>我们在微信上24小时期待你的声音</p> <p>解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流</p> </div> </div> <div class="othernews cl"> <h3>其他资讯</h3> <ul> <li><a href="/article/cdhgjcg.html">如何在Linux系统上安装Nginx?详细步骤教程</a></li><li><a href="/article/cdhgjej.html">概览Linux系统新手指南:初学者版本概览(初学者linux版本)</a></li><li><a href="/article/cdhgjih.html">如何在数据库中添加新的字段(SQL)(数据库sql添加字段)</a></li><li><a href="/article/cdhgjig.html">windows2008r2搭建web服务器(怎样使用windowsserver2008搭建web服务器并建立个人网站?)</a></li><li><a href="/article/cdhgjge.html">虚拟主机连接中断的原因有哪些</a></li> </ul> </div> </div> </div> <div class="sidebar"> <div class="tuijian"> <a href="#"> <h2 class="cl"><span>行业动态</span></h2> <h3>企业网站建设的重要性!</h3> <p>现在虽然是移动互联网时代,但企业网站依然重要,包含PC站点,移动站。可以说企业网站关系企业的未来发展和前途,尤其对中小企业更是如此,一些中小企业老板,对自己的名片很在乎,因为这是个门面。...</p> </a> </div> <div class="ser sidesub"> <h2>服务项目</h2> <ul class="ebox"> <li class="sub sub-1"> <div> <h3>网站建设</h3> <p></p> <a class="btn" href="/serve/website/">查看详情</a> </div> </li> <li class="sub sub-1"> <div> <h3>移动端/APP</h3> <p></p> <a class="btn" href="/serve/moblie/">查看详情</a> </div> </li> <li class="sub sub-1"> <div> <h3>微信/小程序</h3> <p></p> <a class="btn" href="/serve/small/">查看详情</a> </div> </li> <li class="sub sub-1"> <div> <h3>技术支持</h3> <p></p> <a class="btn" href="/serve/tech/">查看详情</a> </div> </li> <li class="sub sub-1"> <div> <h3>其它服务</h3> <p></p> <a class="btn" href="/serve/othe/">查看详情</a> </div> </li> <li class="sub sub-5"> <div> <h3>更多服务项目</h3> <p> <a>用我们的专业和诚信赢得您的信赖,从PC到移动互联网均有您想要的服务!</a></p> <a class="btn" href="/serve/">获取更多</a> </div> </li> </ul> </div> <div class="contact" id="fix"> <h2 class="cl"> <span>联系吧</span> <a href="https://map.baidu.com/" class="ditu" rel="nofollow" target="_blank">在百度地图上找到我们</a> </h2> <h3>电话:13518219792</h3> <p>如遇占线或暂未接听请拨:136xxx98888</p> <div class="qq"> <a href="//wpa.qq.com/msgrd?v=3&uin=244261566&site=qq&menu=yes" rel="nofollow" target="_blank">业务咨询</a> <a href="//wpa.qq.com/msgrd?v=3&uin=244261566&site=qq&menu=yes" rel="nofollow" target="_blank">技术咨询</a> <a href="//wpa.qq.com/msgrd?v=3&uin=244261566&site=qq&menu=yes" rel="nofollow" target="_blank">售后服务</a> </div> </div> </div> <script> //固定滚动 (function () { var oDiv = document.getElementById("fix"); var H = 120, iE6; var Y = oDiv; while (Y) { H += Y.offsetTop; Y = Y.offsetParent }; iE6 = window.ActiveXObject && !window.XMLHttpRequest; if (!iE6) { window.onscroll = function () { var s = document.body.scrollTop || document.documentElement.scrollTop; if (s > H) { oDiv.className = "contact fixed"; if (iE6) { oDiv.style.top = (s - H) + "px"; } } else { oDiv.className = "contact "; } }; } })(); </script> </div> <div class="footer"> <div class="wp"> <div class="wpss cl"> <dl class="about"> <dt>网站设计</dt> <dd><a href="http://m.cdcxhl.com/" target="_blank" title="成都网站设计">成都网站设计</a></dd><dd><a href="http://www.cxjianzhan.cn/fwxm/pinpai.html" target="_blank" title="成都品牌网站设计">成都品牌网站设计</a></dd><dd><a href="http://www.kswcd.com/" target="_blank" title="企业网站设计">企业网站设计</a></dd><dd><a href="http://www.cdkjz.cn/fangan/" target="_blank" title="企业网站设计">企业网站设计</a></dd> </dl> <dl class="about"> <dt>网站制作</dt> <dd><a href="http://www.cqcxhl.com/" target="_blank" title="重庆网站制作">重庆网站制作</a></dd><dd><a href="https://www.cdcxhl.com/" target="_blank" title="成都网站制作">成都网站制作</a></dd><dd><a href="http://chengdu.cdxwcx.cn/wangzhan/" target="_blank" title="手机网站制作">手机网站制作</a></dd><dd><a href="https://www.cdxwcx.com/" target="_blank" title="成都网站制作">成都网站制作</a></dd> </dl> <dl class="contact"> <dt>联系我们</dt> <dd>电话:13518219792</dd> <dd>邮箱:631063699@qq.com</dd> <dd>地址:成都青羊区锦天国际1002号</dd> <dd>网址:www.gxwzsj.com</dd> </dl> <dl class="about" style="margin-left:50px;width:235px;"> <dt>网站建设</dt> <dd><a href="http://m.cdcxhl.cn/shop/" target="_blank" title="成都商城网站建设">成都商城网站建设</a></dd><dd><a href="https://www.cdxwcx.com/city/leshan/" target="_blank" title="乐山网站建设">乐山网站建设</a></dd><dd><a href="https://www.cdxwcx.com/city/nanchong/" target="_blank" title="南充网站建设">南充网站建设</a></dd><dd><a href="https://www.cdcxhl.com/" target="_blank" title="网站建设">网站建设</a></dd> </dl> <dl class="flow"> <dt></dt> <div class="ma cl"> <div class="m"> <img src="/Public/Home/images/ew.jpg" /> <p>微信二维码</p> </div> </div> </dl> </div> </div> <div class="footer-link wp"> <ul class="wpss cl"> <li class="fisrt">友情链接</li> <li><a href="http://chengdu.cdxwcx.cn/" title="成都网站建设" target="_blank">成都网站建设</a></li><li><a href="http://www.rfxuruidl.com/" title="成都高压电缆敷设" target="_blank">成都高压电缆敷设</a></li><li><a href="https://www.cdxwcx.com/wangzhan/case/dfjg.html" title="东电技服" target="_blank">东电技服</a></li><li><a href="http://www.cdpanxi.com/" title="企业网站设计" target="_blank">企业网站设计</a></li><li><a href="http://www.dyfdjgs.com/" title="德阳发电机销售" target="_blank">德阳发电机销售</a></li><li><a href="http://www.bkrjx.com/" title="成都公司注册代办" target="_blank">成都公司注册代办</a></li><li><a href="http://www.zsypzc.com/" title="巴中柴油发电机销售" target="_blank">巴中柴油发电机销售</a></li><li><a href="http://www.ysfsjgs.com/" title="书籍刊物设计" target="_blank">书籍刊物设计</a></li><li><a href="https://www.cdcxhl.com/wangzhandingzhi.html" title="成都企业网站定制" target="_blank">成都企业网站定制</a></li><li><a href="http://seo.cdcxhl.cn/" title="成都网站推广" target="_blank">成都网站推广</a></li> </ul> </div> </div> <div class="bot-footer"> <div class="wp"> <p class="wpss"> <em>Copyright © 2013-2025 www.gxwzsj.com 浩康建站品牌广西站 QQ:244261566 版权所有</em> <em>备案号:<a href="http://beian.miit.gov.cn/" rel="external nofollow">蜀ICP备17025366号</a></em> </p> <p class="wpss" style="line-height:30px !important;"> </p> </div> </div> <div class="footer-kefu"> <ul> <li class="qq"><a href="https://wpa.qq.com/msgrd?v=3&uin=244261566&site=qq&menu=yes"><em></em>在线咨询</a> </li> <li class="tel"><a href="tel:13518219792" target="_blank"><em></em>13518219792</a></li> <li class="wx"> <em></em> <div class="code"> <img src="/Public/Home/images/ew.jpg" /> <p>微信二维码</p> </div> </li> <li class="m"> <em></em> <div class="code"> <img src="/Public/Home/images/ew.jpg" /> <p>移动版官网</p> </div> </li> <li class="top"><em></em></li> </ul> </div> <script src="/Public/Home/js/all.js"></script> </body> </html> <script> $(".cont img").each(function(){ var src = $(this).attr("src"); //获取图片地址 var str=new RegExp("http"); var result=str.test(src); if(result==false){ var url = "https://www.cdcxhl.com"+src; //绝对路径 $(this).attr("src",url); } }); window.onload=function(){ document.oncontextmenu=function(){ return false; } } </script>