Html DOM树的结构和访问

开发 前端
本文向大家简单介绍一下Html DOM树的概念和用法,DOM是一种与平台和语言无关的接口,它允许程序和脚本动态访问和修改文档的内容、结构和类型。它定义了一系列的对象和方法对Html DOM树的节点进行各种随机操作。

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

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. <XMLIDXMLID=“dsoDetails”src=“Books.xml”></XML> 
  2. Setdoc=dsoDetails.XMLDocument  
  3.  

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

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  
  2.  

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

  1. <xmlidxmlid=“dsoBooks”> 
  2. <?xmlversionxmlversion=“1.0”?><booklist><book> 
  3. <title>TheGourmetMicrowave</title> 
  4. <price>9.95</price> 
  5. <author>CharlotteM.Cooper</author> 
  6. <author>ShelleyB.Burke</author> 
  7. <author>ReginaP.Murphy</author> 
  8. </book><book> 
  9. <title>Sushi,Anyone?</title> 
  10. <price>14.99</price></book><book> 
  11. <title>StraightTalkAboutComputers</title>
  12. <price>19.99</price> 
  13. <author>LarsPeterson</author> 
  14. </book></booklist></xml> 
  15.  

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

 

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

◆根节点:theNode.ownerDocument返回Document节点,指向XML文档本身;
◆兄弟节点:theNode.previousSibling返回第1个<book>元素,theNode.nextSibling返回第3个<book>元素;
◆父节点:theNode.parentNode返回<booklist>元素;
◆子节点:theNode.firstChild返回<title>元素,theNode.lastChild返回<price>元素,theNode.childNodes返回子节点集合,包括Sushi下面的所有元素。节点记数从0开始,即theNode.childNodes(0)的结果与theNode.firstChild的结果是一样的。

获得节点的引用后,就可以读取节点的相关信息:

◆节点类型:theNode.nodeType,本例为1,Document对象类型为9,元素类型为1,属性类型为2;
◆节点名称:theNode.nodeName,本例为book;
◆节点值:theNode.nodeValue,本例为null,对于Attr节点,返回的是属性值,而对于Element节点,返回的是null。

在MSXML中,对Node对象还提供了一些额外的方法和属性:

◆nodeTypeString:用字符串的方式显示节点类型,如theNode.nodeTypeString的结果是“element”;
◆text:显示当前节点及其所有子节点的文本内容;
◆xml:获取XML文档数据,通常是从根元素开始的所有内容。#p#

4.XML格式的动态转换

通过学习XSL,我们已经能够使用样式单对XML文档进行转换。但这种过程是静态的,即在编写代码时,已经指定了作用在XML上的XSL文件,在程序运行过程中不能再做改变。而利用DOM,我们能够实现XML格式的动态转换,即在程序运行时,将XSL载入并对XML文档进行转换。

把XSL载入DOM对象的步骤基本上与XML文档的载入过程是一样的(XSL本身就是XML文档): 

  1. Setstylesheet=CreateObject(“Microsoft.XMLDOM”)  
  2. stylesheet.async=False 
  3. stylesheet.load“TransformDetails.xsl” 

DOM提供了两个函数进行这种转换,作用对象可以是树中任何节点。这样就可以实现对Html DOM树的任意的部分进行格式转换。
◆transformNodeToObject方法:该方法需要两个参数,第一个参数指向XSL文件,第二个参数存放转换后的XML数据的节点。例如: 

  1. SettargetNode=CreateObject(“Microsoft.XMLDOM”)  
  2. srcNode.transformNodeToObjectstylesheet,targetNode  
  3.  

◆transformNode方法:该方法只需要一个参数指明XSL文件。如下例是将源节点转换为一个字符串变量str:
 

  1. str=srcNode.transformNode(stylesheet)  
  2.  

【编辑推荐】

  1. JavaScript DOM特性与应用详解
  2. W3C DOM模型用法详解
  3. JavaScript获取HTML DOM节点元素详解
  4. 深入了解JavaScript HTML DOM对象
  5. 解析HTML DOM Checkbox对象的属性和方法
责任编辑:佚名 来源: blog.csdn.net
相关推荐

2010-09-28 16:22:17

DOM树

2010-09-28 11:11:23

XML DOMHTML DOM

2010-08-23 13:29:43

HTMLpadding

2010-09-28 12:59:45

JavaScriptDOM

2009-07-09 10:15:23

PHP DOM

2010-09-28 10:33:59

HTML DOM Ch

2010-09-09 17:19:07

HTML DOMXML DOM

2010-09-28 10:24:50

HTML DOMXML DOM

2010-09-28 10:40:32

HTML DOM

2011-07-26 10:46:04

HTML 5

2020-12-08 06:19:33

爬虫Dom树组件

2010-09-08 17:26:46

JavaScript

2023-02-23 19:32:03

DOMJavascript开发

2010-10-08 10:35:21

2010-09-28 11:32:30

HTML DOM是什么

2010-09-10 14:12:07

JavaScript

2010-09-13 13:58:17

HTML DOM

2010-09-13 16:46:29

JavaScriptHTML DOM节点

2010-09-15 14:40:07

HTMLposition属性

2010-09-28 09:14:36

HTML DOMJavascript
点赞
收藏

51CTO技术栈公众号