From:http://soft.zdnet.com.cn/software_zone/2007/1004/535320.shtml
1、简介
xmlDOM被设计为可用于任何语言和任何操作系统。借助DOM,程序员可以创建xml文档、遍历其结构,增、改、删其元素。DOM将整个xml文档视作一棵树,文档级的元素是树的根
2.结构:
举一实例
分析:
Document节点:即文档对象,树的最高节点,对整个文档进行操作的入口
Element和Attribute节点:这些结点对象是对整个文档进行操作的入口
Text节点类型,Text对象表达了元素或者属性的文本内容,Text节点不再包含任何子节点
集合索引:对节点按指定方式进行遍历,索引参数从0开始
3.Document对象
属性:
async 属性 | |||
作 用 |
async 属性表示是否允许异步的下载。 | ||
基本语法 | |||
说 明 | 布尔值是可擦写的(read/write),如果准许异步下载,值为True;反之则为False。 | ||
范 例 |
attribute 属性
alert(objAttList);
childNodes 属性
alert(objNodeList);
传回文件型态节点,包含目前文件的DTD。这节点是一般的文件型态宣告,例如,节点,名为EMAIL 的节点物件会被传回。 |
objDocType=xmlDocument.doctype; |
传回一个对象,这个属性是只读的。假如这文件不包含DTD,会传回null。 |
objDocType=xmlDoc.doctype; alert(objDocType.nodeName); |
确认xml文件的根(Root)节点。 |
objDoc=xmlDocument.documentElement; |
回一个在单一根文件元素中包含数据的对象。此属性可读/写,如果文件中不包含根节点,将传回null。 |
objDocRoot=xmlDoc.documentElement; alert(objDocRoot); |
确认在目前节点中的第一个子元素。 |
objFirstChild =xmlDocNode.firstChild ; |
此属性只读且会传回一对象,如果节点中没有包含第一个子元素,将传回null。 |
objFirstChild=xmlDoc.documentElement.firstChild; alert(objFirstChild); |
DOM 应用程序能使用其它实作中的对象。implementation 属性确认目前xml文件的DOMimplementation 对象。 |
objImplementation =xmlDocument.implementation; |
此属性只读且传回一个对象。 |
objImp=xmlDoc.implementation; alert(objImp |
parseError 属性
alert(objParseErr);
传回目前节点之前的兄弟节点。 |
objPrevSibling =xmlDocument.prevIoUsSibling; |
传回一个对象,这个属性是只读的。若该节点没有包含前面的兄弟节点,会传回null。 |
objPrevSibling= xmlDoc.documentElement.childNodes.item(3).prevIoUsSibling alert(objPrevSibling); |
传回xml文件资料的目前状况。 |
intState =xmlDocument.readyState; |
这个属性是只读的,传回值有以下的可能: 0-UNINITIALIZED:xml对象被产生,但没有任何文件被加载。 1-LOADING:加载程序进行中,但文件尚未开始解析。 2-LOADED:部分的文件已经加载且进行解析,但对象模型尚未生效。 3-INTERACTIVE:仅对已加载的部分文件有效,在此情况下,对象模型是有效但只读的。 4-COMPLETED:文件已完全加载,代表加载成功。 |
alert("ThereadyStatepropertyis"+xmlDoc.readyState); |
传回最近一次加载xml文件的URL。 |
strDocUrl =xmlDocument.url; |
这个属性是只读的,传回最近一次加载成功文件的URL,若文件仅存在主存储器中(表示该文件并非由外部档案加载),则传回null。 |
alert(xmlDoc.url); |
告诉解析器文件是否有效。 |
boolValidate=xmlDocument.validateOnParse; xmlDocument.validateOnParse=boolValidate; |
此属性是可擦写的。如果传回值为true,表示文件被解析时被确认是有效的。如果传回false,表示文件是无效的,并被认为只是标准格式的(well-formed)文件。 |
xmlDoc.validateOnParse=true; alert(xmlDoc.validateOnParse); |
方法:
createAttribute 方法
alert(objNewAtt.xml);
作 用 |
xmlDocument.createCDATASection(data); |
date 是一个字符串,且包含了被置放在CDATA 的资料。 |
objNewCDATA=xmlDoc.createCDATASection("ThisisaCDATASection"); alert(objNewCDATA.createComment 方法 |
xmlDocument.createComment(data); |
data 是一个字符串,且包含了被置放在批注的资料。 |
objNewComment=xmlDoc.createComment("Thisisacomment"); alert(objNewComment.createDocumentFragment 方法 |
建立一个空的文件片断对象。 |
xmlDocument.createDocumentFragment(); |
一个新的文件片断被建立,但没有加到文件树中。要加入片断到文件树中,必须使用插入方法,例如insertBefore、replaceChild 或appendChild。 |
objNewFragment=xmlDoc.createDocumentFragment(); alert(objNewFragment.createElement 方法 |
建立一个指定名称的元素。 |
xmlDocument.createElement(tagName); |
tagName 是一个区分大小写的字符串来指定新元素名称。 |
objNewElement=xmlDoc.createElement("TO"); alert(objNewElement.createEntityReference 方法 |
建立一个参照到指定名称的实体。 |
xmlDocument.createEntityReference(name); |
name 是一个区分大小写的字符串,来指定新实体参照的名称。一个新的实体参照被建立,但是并没有被加到文件树中。若要将实体参照加到文件树中,必须使用一种插入方法,例如:insertBefore,replaceChild,或appendChild。 |
objNewER=xmlDoc.createEntityReference("eRef"); alert(objNewER.createNode 方法 |
建立一个指定型态、名称,及命名空间的新节点。 |
xmlDocument.createNode(type,name,nameSpaceURI); |
type 用来确认要被建立的节点型态,name 是一个字符串来确认新节点的名称,命名空间的前缀则是选择性的。nameSpaceURI 是一个定义命名空间URI 的字符串。如果前缀被包含在名称参数中,此节点会在nameSpaceURI 的内文中以指定的前缀建立。如果不包含前缀,指定的命名空间会被视为预设的命名空间。 |
objNewNode=xmlDoc.createNode(1,"TO",""); alert(objNewNode.createProcessingInstruction 方法 |
建立一个新的处理指令,包含了指定的目标和数据。 |
xmlDocument.createProcessingInstruction(target,data); |
target 是表示目标、名称或处理指令的字符串。Data 是表示处理指令的值。一个新的处理指令被建立,但是并没有加到文件树中。要把处理指令加到文件树中,必须使用插入方法,例如:insertBefore、replaceChild,或是appendChild。 |
objNewPI=xmlDoc.createProcessingInstruction(‘xml’,‘version="1.0"’); alert(objNewPI.xml); |
建立一个新的text 节点,并包含指定的xmlDocument.createTextNode(data); |
data 是一个代表新text 节点的字符串。一个新的text 节点被建立,但是没有加到文件树中。若要将节点加到文件树中,必须使用插入方法,例如:insertBefore,replaceChild或appendChild。 |
objNewTextNode=xmlDoc.createTextNode("Thisisatextnode."); alert(objNewTextNode.getElementsByTagName 方法 |
传回指定名称的元素集合。 |
objNodeList =xmlDocument.getElementsByTagName(tagname); |
tagname 是一个字符串,代表找到的元素卷标名称。使用tagname "*"传回文件中所有找到的元素。 |
xmlDoc.getElementsByTagName("*"); alert(objNodeList.item(1).xml); |
load 方法
alert(boolValue);
加载一个xml文件或字符串的片断。 |
xmlDocument.loadxml(xmlString); |
xmlString 是包含xml文字码的字符串。 |
xmlString="<GREETING><MESSAGE>Hello!</MESSAGE></GREETING>"; boolValue=xmlDoc.loadxmlString); alert(boolValue); |
nodeFromID 方法 | ||||
传回节点ID 符合指定值的节点。 | ||||
xmlDocumentNode =xmlDocument.nodeFromID(idString); | ||||
idString 是一个包含ID 值的字符串。符合的节点必定是ID 型态。若符合,将传回一个对象;若操作失败,则传回null。 | ||||
objDocumentNode=xmlDoc.nodeFromID("TO"); alert(objDocumentNode); |
selectNodes 方法
alert(objNodeList.item(0).xml);
4.Node对象
Node对象表示树中的一个节点
lastChild 属性
alert(objLastChild);
在目前文件节点的子节点列表中传回下一个兄弟节点。 |
objNextSibling =xmlDocNode.nextSibling; |
此属性是只读且传回一个对象。如果节点中没有包含其它的相关节点,会传回null。 |
objSibling=xmlDoc.documentElement.childNodes.item(1).nextSibling; alert(objSibling); |
传回代表目前节点名称的字符串。 |
strNodeName =xmlDocNode.nodeName ; |
传回一个字符串。这个属性是只读的,传回元素名称、属性或实体参照。 |
strNodeName=xmlDoc.documentElement.nodeName; alert(strNodeName); |
辨识节点的DOM 型态。 |
numNodeType =xmlDocNode.nodeType ; |
此属性只读且传回一个数值。 有效的数值符合以下的型别: 1-ELEMENT 2-ATTRIBUTE 3-TEXT 4-CDATA 5-ENTITYREFERENCE 6-ENTITY 7-PI(processinginstruction) 8-COMMENT 9-DOCUMENT 10-DOCUMENTTYPE 11-DOCUMENTFRAGMENT 12-NOTATION |
numNodeType=xmlDoc.documentElement.nodeType; alert(numNodeType); |
传回指定节点相关的文字。这并非一个元素中数据的值,而是与一个节点相关且未解析的文字,就像一个属性或者一个处理指令。 |
varNodeValue =xmlDocNode.nodeValue; |
传回的文字代表以节点的nodeType 属性为主的型态值。(请参考附录中的nodeType 属性。)因为节点型态可能是几种数据型态中的一种,传回值也因此有差异。传回null 的节点型态有:DOCUMENT、ELEMENT、DOCUMENT TYPE、DOCUMENT FRAGMENT、ENTITY、ENTITY REFERENCE,和NOTATION。此属性可擦写。 |
varNodeValue=xmlDoc.documentElement.nodeValue; alert(varNodeValue); |
指定一个事件来处理ondataavailable 事件。 |
xmlDocNode.ondataavailable = value; |
此属性是唯写,允许文件作者一旦数据为可用,即可尽快的使用数据来运作。 |
xmlDoc.ondataavailable=alert("Dataisnowavailable."); |
指定一个事件来处理onreadystatechange 事件。这个事件能辨识readyState 属性的改变。 |
xmlDocNode.onreadystatechange = value; |
此属性是唯写的,允许文件作者指定当readyState 属性改变时呼叫事件。 |
xmlDoc.onreadystatechange= alert("ThereadyStatepropertyhaschanged."); |
xml属性
alert(xmlValue);
AppendChild 方法
alert(docObj.xml);
objNewNode=docObj.appendChild(xmlDoc.documentElement.firstChild);
alert(docObj.cloneNode 方法
objClonedNode=currNode.cloneNode(1);
alert(objClonedNode.haschildnodes 方法
alert(boolValue);
在指定的节点前插入一个子节点。 |
objDocumentNode =xmlDocumentNode.insertBefore(newChild,refChild); |
newChild 是一个包含新子节点地址的对象,refChild 是参照节点的地址。新子节点被插到参照节点之前。如果refChild 参数没有包含在内,新的子节点会被插到子节点列表的末端。 |
objRefNode=xmlDoc.documentElement; alert(xmlDoc.xml); objNewNode=xmlDoc.createComment("Thisisacomment"); xmlDoc.insertBefore(objNewNode,objRefNode); alert(parsed 方法 |
会验证该指定的节点(node)及其衍生的子节点(descendants)是否已被解析过。 |
xmlDocumentNode.parsed(); |
如果全部的节点都已经被解析过了,则传回值为ture;如果有任何一个节点尚未被解析,传回值则为false。 |
currNode=xmlDoc.documentElement.childNodes.item(0); boolValue=currNode.parsed(); alert(boolValue); |
会将指定的节点从节点清单中移除。 |
xmlDocumentNode.removeChild(oldChild); |
oldChild 为一个包含要被移除的节点对象。 |
objRemoveNode=xmlDoc.documentElement.childNodes.item(3); alert(xml); xmlDoc.documentElement.removeChild(objRemoveNode); alert(xml); |
置换指定的旧子节点为提供的新子节点。 |
xmlDocumentNode.replaceChild(newChild,oldChild); |
newChild 为包含新子节点的对象。如果此参数为null,则此旧子节点会被移除而不会被取代。oldChild 为包含旧子节点的对象。 |
objOldNode=xmlDoc.documentElement.childNodes.item(3); objNewNode=xmlDoc.createComment("I'vereplacedtheBCCelement."); alert(xml); xmlDoc.documentElement.replaceChild(objNewNode,objOldNode); alert(selectSingleNode 传回第一个符合样式的节点。 |
传回第一个符合样式的节点。 |
xmlDocumentNode.selectSingleNode(patternString); |
patternString 为一包含XSL 样式的字符串。此方法会传回第一个符合的节点对象,如果没有符合的节点,则传回null。 |
objNode=xmlDoc.selectSingleNode("EMAIL/BCC"); alert(objNode.transformNode 方法 |
使用提供的样式表来处理该节点及其子节点。 |
strTransformedDocument =xmlDocumentNode.transformNode(stylesheet); |
stylesheet 为一xml文件或是片断包含负责节点转换工作的XSL 元素。此方法会传回一包含转换结果的字符串。 |
varstyle=newActiveXObject("Microsoft.xmlDOM"); style.load("LstA_49.xsl"); strTransform=xmlDoc.transformNode(style.documentElement); alert(strTransform); |