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> <p> 当前题目:<a href="http://www.sclezhi.cn/qtweb/news25/65475.html">HtmlDOM树的结构和访问</a> <br> 文章链接:<a href="http://www.sclezhi.cn/qtweb/news25/65475.html">http://www.sclezhi.cn/qtweb/news25/65475.html</a> </p> <p> <a href="https://www.cdcxhl.com/" target="_blank">成都网站建设公司</a>_<a href="https://www.cdcxhl.cn/" target="_blank">创新互联</a>,为您提供<a href="https://www.cdcxhl.com/news/pinpaizhizuo/">品牌网站制作</a>、<a href="https://www.cdcxhl.com/news/wysjgs/">网页设计公司</a>、<a href="https://www.cdcxhl.com/news/zishiying/">自适应网站</a>、<a href="https://www.cdcxhl.com/news/shejigongsi/">网站设计公司</a>、<a href="https://www.cdcxhl.com/news/sosuo/">搜索引擎优化</a>、<a href="https://www.cdcxhl.com/news/appkaifa/">App开发</a> </p> <p class="adpic"> <a href="https://www.cdcxhl.com/service/ad.html" target="_blank" class="ad">广告</a> <a href="" target="_blank" class="adimg"><img src=""></a> </p> <p class="copy"> 声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: <a href="https://www.cdcxhl.com/" target="_blank">创新互联</a> </p> </div> <div class="newsmorelb"> <p>猜你还喜欢下面的内容</p> <ul> <li> <a href="/qtweb/news24/65474.html">电脑出现windows帮助和支持怎么办?windows的帮助系统</a> </li><li> <a href="/qtweb/news23/65473.html">电子商城java建站需要多少钱,可以通过哪些方面来判断?</a> </li><li> <a href="/qtweb/news22/65472.html">oppor9plus指纹支付怎么设置,OPPO R9plus微信指纹支付怎么办弄</a> </li><li> <a href="/qtweb/news21/65471.html">redis的主从复制是如何工作的</a> </li><li> <a href="/qtweb/news20/65470.html">系统Linux的新分支:走向下一个级别(linux的分支)</a> </li><li> <a href="/qtweb/news19/65469.html">Linux系统扩展根分区具体方法</a> </li><li> <a href="/qtweb/news18/65468.html">DEDECMS怎么获取当前栏目及所有子栏目的文章数量</a> </li><li> <a href="/qtweb/news17/65467.html">怎么拷u盘</a> </li><li> <a href="/qtweb/news16/65466.html">从Linux命令行掌控计算机:实用的Linux命令应用(linux命令应用)</a> </li> </ul> </div> </div> <div class="col-lg-3 noneb"> <div class="bkright" style="margin-top: 0"> <p><a href="https://www.cdcxhl.com/news/jianshe/">网站建设知识</a></p> <ul> <li> <a class="text_overflow" href="/qtweb/news7/83657.html">如何将关系型数据导入MongoDB?</a> </li><li> <a class="text_overflow" href="/qtweb/news19/98069.html">自己制作的图片,怎样有链接?(景安免费空间)</a> </li><li> <a class="text_overflow" href="/qtweb/news9/79159.html">子域名ip地址查询?(查询子域名网)</a> </li><li> <a class="text_overflow" href="/qtweb/news35/103335.html">如何制作令人印象深刻的阿里旺铺板块标题</a> </li><li> <a class="text_overflow" href="/qtweb/news2/81102.html">php空值是什么意思</a> </li><li> <a class="text_overflow" href="/qtweb/news21/107271.html">如何在MySQL数据库中创建新用户(给msql数据库创建一个用户)</a> </li><li> <a class="text_overflow" href="/qtweb/news40/100640.html">什么单机Redis使用它来存储何物(单机redis能存储)</a> </li><li> <a class="text_overflow" href="/qtweb/news44/70344.html">Redis离线命令指南高效率掌握基础指令(redis离线命令手册)</a> </li><li> <a class="text_overflow" href="/qtweb/news22/96172.html">HTML5WebSocket实现实时视频文字传输</a> </li><li> <a class="text_overflow" href="/qtweb/news25/85275.html">SSL证书申请流程(ssl证书申请流程是什么)</a> </li><li> <a class="text_overflow" href="/qtweb/news11/85761.html">退虚拟主机-其他问题</a> </li><li> <a class="text_overflow" href="/qtweb/news40/83340.html">LINUXEXP文件:解密Linux上的实验室探秘(linuxexp文件)</a> </li><li> <a class="text_overflow" href="/qtweb/news8/97458.html">服务器怎么使用啊?(如何用好服务器)</a> </li><li> <a class="text_overflow" href="/qtweb/news46/100146.html">问答Fortinet全球安全战略官DerekManky</a> </li><li> <a class="text_overflow" href="/qtweb/news40/89290.html">php如何防止表单重复提交表单</a> </li> </ul> </div> <div class="bkright tag"> <p><a href="https://www.cdcxhl.com/hangye/" target="_blank">分类信息网</a></p> <ul> <li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/yhjdsj/" target="_blank">宴会酒店设计</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/jizhuangxiang/" target="_blank">集装箱</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/sdjbc/" target="_blank">隧道混凝土搅拌车</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/pe/" target="_blank">PE包装袋</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/zzdb/" target="_blank">资质代办</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/chayisj/" target="_blank">茶艺设计</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/gangting/" target="_blank">岗亭</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/huaxiang/" target="_blank">花箱</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/blgds/" target="_blank">玻璃钢雕塑</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/sljbc/" target="_blank">生料搅拌车</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/bgcl/" target="_blank">办公窗帘</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/hntjbj/" target="_blank">混凝土搅拌机</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/shidiao/" target="_blank">石雕</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/zdfhw/" target="_blank">主动防护网</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/bolixiufu/" target="_blank">汽车玻璃修复</a> </li><li class="col-lg-6 col-md-6 col-sm-6 col-xs-6"> <a href="https://www.cdcxhl.com/hangye/ruanzhuangsj/" target="_blank">软装设计</a> </li> </ul> </div> </div> </div> <div class="carousel-inner linkbg" style="background: #fff"> <div class="container"> <a href="https://www.cdxwcx.com/wangzhan/app.html" target="_blank">App开发</a>    <a href="https://www.cdcxhl.com/shop.html" target="_blank">商城网站建设</a>    <a href="http://www.kswsj.com/" target="_blank">成都网站推广</a>    <a href="http://www.024fuxl.com/" target="_blank">成都酒店服定制</a>    <a href="http://www.cdxwcx.cn/tuoguan/" target="_blank">成都服务器托管</a>    <a href="https://www.cdcxhl.com/qiye.html" target="_blank">成都企业网站建设</a>    <a href="https://www.cdxwcx.com/city/wenjiang/" target="_blank">温江做网站</a>    <a href="https://www.cdxwcx.com/city/jianyang/" target="_blank">简阳网站建设</a>    <a href="http://www.gtmaxf.cn/" target="_blank">消防工程</a>    <a href="http://chengdu.cdcxhl.com/" target="_blank">成都网站制作</a>    <a href="http://www.cdxwcx.cn/tuoguan/guanghua.html" target="_blank">成都电信光华数据中心</a>    <a href="http://www.yunjinzhai.com/" target="_blank">云锦斋建筑</a>    <a href="http://www.cqcxhl.com/" target="_blank">网站建设公司</a>    <a href="http://www.kswcd.com/" target="_blank">企业网站设计</a>    <a href="http://www.4006tel.net/mobile/" target="_blank">手机APP开发</a>    <a href="http://www.cdkjz.cn/wangzhan/qiye/" target="_blank">成都企业网站建设</a>    <a href="http://www.kswcd.com/solution/" target="_blank">网站方案</a>    <a href="http://www.cdhuace.com/" target="_blank">户外广告设计</a>    <a href="http://www.4006tel.net/yingxiao/" target="_blank">企业营销型网站</a>    <a href="https://www.cdcxhl.cn/ " target="_blank">香港空间腾讯云</a>     </div> </div> <footer> <div class="carousel-inner footjz"> <div class="container"> <i class="icon iconfont zbw"></i> 高品质定制 <i class="icon iconfont"></i> 跨终端自动兼容 <i class="icon iconfont"></i> 节约开发成本 <i class="icon iconfont"></i> 开发周期短 <i class="icon iconfont"></i> 一体化服务 <button type="button" class="btn btn-default btn-lg" onClick="window.location.href='tencent://message/?uin=631063699&Site=&Menu=yes'"> 立即开始2800定制网站建设</button> <button type="button" class="btn btn-default btn-xs" onClick="window.location.href='tencent://message/?uin=631063699&Site=&Menu=yes'"> 2800定制网站建设</button> </div> </div> <div class="carousel-inner bqsy"> <div class="container"> <div class="lxfs"> <h4 class="yutelnone">028-86922220 13518219792</h4> <h4 class="yutelblock"><a href="tel:02886922220">028-86922220</a> <a href="tel:13518219792">13518219792</a></h4> <a class="btn btn-default" href="tencent://message/?uin=532337155&Site=&Menu=yes" role="button">网站建设<span>QQ</span>:532337155</a> <a class="btn btn-default" href="tencent://message/?uin=631063699&Site=&Menu=yes" role="button">营销推广<span>QQ</span>:631063699</a> <a class="btn btn1 btn-default" href="mqqwpa://im/chat?chat_type=wpa&uin=532337155&version=1&src_type=web&web_src=oicqzone.com" role="button">网站制作<span>QQ</span>:532337155</a> <a class="btn btn1 btn-default" href="mqqwpa://im/chat?chat_type=wpa&uin=631063699&version=1&src_type=web&web_src=oicqzone.com" role="button">营销推广<span>QQ</span>:631063699</a> <a class="btn btn-default nonea" href="tencent://message/?uin=1683211881&Site=&Menu=yes" role="button">售后QQ:1683211881</a> <div class="dz">创新互联建站专注: <a href="https://www.cdcxhl.com/" target="_blank">网站设计</a> <a href="https://www.cdcxhl.com/" target="_blank">网站制作</a> <a href="https://www.cdcxhl.com/" target="_blank">网站建设</a> <address>地址:成都太升南路288号锦天国际A幢10楼</address> </div> </div> <div class="bzdh dz"><img src="https://www.cdcxhl.com/imges/bottom_logo.png" alt="创新互联"> <p><a href="https://www.cdcxhl.com/menu.html" target="_blank">成都创新互联科技有限公司</a><br> Tel:400-028-6601(7x24h)</p></div> </div> </div> </footer> </body> </html> <script> $.getJSON ("../../qtwebpic.txt", function (data) { var jsonContent = { "featured":data } var random = jsonContent.featured[Math.floor(Math.random() * jsonContent.featured.length)]; $(".adpic .adimg").attr("href",random.link) $(".adpic img").attr("src",random.pic); }) </script>