Microsoft.xmldom介绍以及api文档及相关资料
来源:互联网 发布:java前后端数据交互 编辑:程序博客网 时间:2024/04/30 07:26
XML DOM介绍、例子以及Microsoft.xmldom api文档
1.文档对象模型(DOM)
DOM是HTML和XML文档的编程基础,它定义了处理执行文档的途径。编程者可以使用DOM增加文档、定位文档结构、填加修改删除文档元素。W3C的重要目标是把利用DOM提供一个使用于多个平台的编程接口。W3C DOM被设计成适合多个平台,可使用任意编程语言实现的方法。
2.节点接口
XML parser用来装载XML文档到缓存中,文档装载时,可以使用DOM进行检索和处理。DOM采用树形结构表示XML文档,文档元素是树的最高阶层,该元素有一个或多个孩子节点用来表示树的分枝。
节点接口程序通常用来读和写XML节点树中的个别元素,文档元素的孩子节点属性可以用来构造个别元素节点。XML parser用来证明Web中的DOM支持遍历节点树的所有函数,并可通过它们访问节点和及其属性、插入删除节点、转换节点树到XML中。
所有Microsoft XML parser函数得到W3C XML DOM的正式推荐,除了load和loadXML函数(正式的DOM不包括标准函数loading XML文档)。有13个节点类型被Microsoft XML parser支持,下面列出常用节点:
节点类型例子
Document type <!DOCTYPE food SYSTEM “food.dtd”>
Processing instruction <?xml version=”1.0″?>
Element <drink type=”beer”>Carlsberg</drink>
Attribute type=”beer”
Text Carlsberg
3.使用XML parser
为了更加熟练的处理XML文档,必须使用XML parser。Microsoft XML parser是IIS5.0所带的一个COM组件,一旦安装了IIS5.0,parser可以利用HTML文档和ASP文件中的脚本。
Microsoft XMLDOM parser支持以下编程模式:
—-支持JavaScript, VBScript, Perl, VB, Java, C++ 等等
—-支持W3C XML 1.0 和XML DOM
—-支持DTD 和validation
如果使用IE5.0中的JavaScript,可以使用下面的XML文档对象:
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
如果使用VBScript,可以使用下面的XML文档对象:
set xmlDoc = CreateObject(”Microsoft.XMLDOM”)
如果使用ASP,可以使用下面的XML文档对象:
set xmlDoc = Server.CreateObject(”Microsoft.XMLDOM”)
4.装载一个XML文件到parser中
下面的代码装载存在的XML文档进入XML parser:
<script language=”JavaScript”>
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”note.xml”)
// ……. processing the document goes here
</script>
第一行脚本增加了一个Microsoft XML parser实例,第三行装载名为”note.xml”的XML文档进入parser中。第二行保证文档装载完成以后parser进行下一步工作。
5. parseError对象
打开XMl文档时,XML Parser产生错误代码,并存在parseError对象中,包括错误代码、错误文本和错误行号,等信息。
6.文件错误
下面的例子将试图装载一个不存在的文件,然后产生相应的错误代码:
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”ksdjf.xml”)
document.write(”<br>Error Code: “)
document.write(xmlDoc.parseError.errorCode)
document.write(”<br>Error Reason: “)
document.write(xmlDoc.parseError.reason)
document.write(”<br>Error Line: “)
document.write(xmlDoc.parseError.line)
7.XML错误
下面使用不正确的格式装载XMl文档,
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”note_error.xml”)
document.write(”<br>Error Code: “)
document.write(xmlDoc.parseError.errorCode)
document.write(”<br>Error Reason: “)
document.write(xmlDoc.parseError.reason)
document.write(”<br>Error Line: “)
document.write(xmlDoc.parseError.line)
8. parseError属性
属性描述:
errorCode 返回长整型错误代码
reason 返回字符串型错误原因
line 返回长整型错误行号
linePos 返回长整型错误行号位置
srcText 返回字符串型产生错误原因
url 返回url装载文档指针
filePos 返回长整型错误文件位置
9.遍历节点树
一种通用的析取XML文档的方法是遍历节点树和它的元素值。下面是使用VBScript写的遍历节点树的程序代码:
set xmlDoc=CreateObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”note.xml”)
for each x in xmlDoc.documentElement.childNodes
document.write(x.nodename)
document.write(”: “)
document.write(x.text)
next
10.为XML文件提供HTML格式
XML的一个优点是把HTML文档和它的数据分离开。通过使用浏览器中的XML parser,HTML页面可以被构造成静态文档,通过JavaScript提供动态数据。下面的例子使用JavaScript读取XML文档,写XML数据成HTML元素:
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”note.xml”)
nodes = xmlDoc.documentElement.childNodes
to.innerText = nodes.item(0).text
from .innerText = nodes.item(1).text
header.innerText = nodes.item(2).text
body.innerText = nodes.item(3).text
11.通过名称访问XML元素
下面的例子使用JavaScript读取XML文档,写XML数据成HTML元素:
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”note.xml”)
document.write(xmlDoc.getElementsByTagName(”from”).item(0).text)
12.装载纯XML文本进入parser
下面的代码装载文本字符串进入XML parser :
<script language=”JavaScript”>
var text=”<note>”
text=text+”<to>Tove</to><from>Jani</from>”
text=text+”<heading>Reminder</heading>”
text=text+”<body>Don’t forget me this weekend!</body>”
text=text+”</note>”
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.loadXML(text)
// ……. processing the document goes here
</script>
13.装载XML进入Parser
<html>
<body>
<script language=”javascript”>
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”note.xml”)
document.write(”The first XML element in the file contains: “)
document.write(xmlDoc.documentElement.childNodes.item(0).text)
</script>
</body>
</html>
遍历XML节点树:
<html>
<body>
<script language=”VBScript”>
txt=”<h1>Traversing the node tree</h1>”
document.write(txt)
set xmlDoc=CreateObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”note.xml”)
for each x in xmlDoc.documentElement.childNodes
document.write(”<b>” & x.nodename & “</b>”)
document.write(”: “)
document.write(x.text)
document.write(”<br>”)
next
</script>
</body>
</html>
装载XML 进入HTML
<html>
<head>
<script language=”JavaScript”
for=”window” event=”onload”>
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”note.xml”)
nodes = xmlDoc.documentElement.childNodes
to.innerText = nodes.item(0).text
from.innerText = nodes.item(1).text
header.innerText = nodes.item(2).text
body.innerText = nodes.item(3).text
</script>
<title>HTML using XML data</title>
</head>
<body bgcolor=”yellow”>
<h1>Refsnes Data Internal Note</h1>
<b>To: </b><span id=”to”></span>
<br>
<b>From: </b><span id=”from”></span>
<hr>
<b><span id=”header”></span></b>
<hr>
<span id=”body”></span>
</body>
1.文档对象模型(DOM)
DOM是HTML和XML文档的编程基础,它定义了处理执行文档的途径。编程者可以使用DOM增加文档、定位文档结构、填加修改删除文档元素。W3C的重要目标是把利用DOM提供一个使用于多个平台的编程接口。W3C DOM被设计成适合多个平台,可使用任意编程语言实现的方法。
2.节点接口
XML parser用来装载XML文档到缓存中,文档装载时,可以使用DOM进行检索和处理。DOM采用树形结构表示XML文档,文档元素是树的最高阶层,该元素有一个或多个孩子节点用来表示树的分枝。
节点接口程序通常用来读和写XML节点树中的个别元素,文档元素的孩子节点属性可以用来构造个别元素节点。XML parser用来证明Web中的DOM支持遍历节点树的所有函数,并可通过它们访问节点和及其属性、插入删除节点、转换节点树到XML中。
所有Microsoft XML parser函数得到W3C XML DOM的正式推荐,除了load和loadXML函数(正式的DOM不包括标准函数loading XML文档)。有13个节点类型被Microsoft XML parser支持,下面列出常用节点:
节点类型例子
Document type <!DOCTYPE food SYSTEM “food.dtd”>
Processing instruction <?xml version=”1.0″?>
Element <drink type=”beer”>Carlsberg</drink>
Attribute type=”beer”
Text Carlsberg
3.使用XML parser
为了更加熟练的处理XML文档,必须使用XML parser。Microsoft XML parser是IIS5.0所带的一个COM组件,一旦安装了IIS5.0,parser可以利用HTML文档和ASP文件中的脚本。
Microsoft XMLDOM parser支持以下编程模式:
—-支持JavaScript, VBScript, Perl, VB, Java, C++ 等等
—-支持W3C XML 1.0 和XML DOM
—-支持DTD 和validation
如果使用IE5.0中的JavaScript,可以使用下面的XML文档对象:
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
如果使用VBScript,可以使用下面的XML文档对象:
set xmlDoc = CreateObject(”Microsoft.XMLDOM”)
如果使用ASP,可以使用下面的XML文档对象:
set xmlDoc = Server.CreateObject(”Microsoft.XMLDOM”)
4.装载一个XML文件到parser中
下面的代码装载存在的XML文档进入XML parser:
<script language=”JavaScript”>
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”note.xml”)
// ……. processing the document goes here
</script>
第一行脚本增加了一个Microsoft XML parser实例,第三行装载名为”note.xml”的XML文档进入parser中。第二行保证文档装载完成以后parser进行下一步工作。
5. parseError对象
打开XMl文档时,XML Parser产生错误代码,并存在parseError对象中,包括错误代码、错误文本和错误行号,等信息。
6.文件错误
下面的例子将试图装载一个不存在的文件,然后产生相应的错误代码:
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”ksdjf.xml”)
document.write(”<br>Error Code: “)
document.write(xmlDoc.parseError.errorCode)
document.write(”<br>Error Reason: “)
document.write(xmlDoc.parseError.reason)
document.write(”<br>Error Line: “)
document.write(xmlDoc.parseError.line)
7.XML错误
下面使用不正确的格式装载XMl文档,
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”note_error.xml”)
document.write(”<br>Error Code: “)
document.write(xmlDoc.parseError.errorCode)
document.write(”<br>Error Reason: “)
document.write(xmlDoc.parseError.reason)
document.write(”<br>Error Line: “)
document.write(xmlDoc.parseError.line)
8. parseError属性
属性描述:
errorCode 返回长整型错误代码
reason 返回字符串型错误原因
line 返回长整型错误行号
linePos 返回长整型错误行号位置
srcText 返回字符串型产生错误原因
url 返回url装载文档指针
filePos 返回长整型错误文件位置
9.遍历节点树
一种通用的析取XML文档的方法是遍历节点树和它的元素值。下面是使用VBScript写的遍历节点树的程序代码:
set xmlDoc=CreateObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”note.xml”)
for each x in xmlDoc.documentElement.childNodes
document.write(x.nodename)
document.write(”: “)
document.write(x.text)
next
10.为XML文件提供HTML格式
XML的一个优点是把HTML文档和它的数据分离开。通过使用浏览器中的XML parser,HTML页面可以被构造成静态文档,通过JavaScript提供动态数据。下面的例子使用JavaScript读取XML文档,写XML数据成HTML元素:
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”note.xml”)
nodes = xmlDoc.documentElement.childNodes
to.innerText = nodes.item(0).text
from .innerText = nodes.item(1).text
header.innerText = nodes.item(2).text
body.innerText = nodes.item(3).text
11.通过名称访问XML元素
下面的例子使用JavaScript读取XML文档,写XML数据成HTML元素:
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”note.xml”)
document.write(xmlDoc.getElementsByTagName(”from”).item(0).text)
12.装载纯XML文本进入parser
下面的代码装载文本字符串进入XML parser :
<script language=”JavaScript”>
var text=”<note>”
text=text+”<to>Tove</to><from>Jani</from>”
text=text+”<heading>Reminder</heading>”
text=text+”<body>Don’t forget me this weekend!</body>”
text=text+”</note>”
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.loadXML(text)
// ……. processing the document goes here
</script>
13.装载XML进入Parser
<html>
<body>
<script language=”javascript”>
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”note.xml”)
document.write(”The first XML element in the file contains: “)
document.write(xmlDoc.documentElement.childNodes.item(0).text)
</script>
</body>
</html>
遍历XML节点树:
<html>
<body>
<script language=”VBScript”>
txt=”<h1>Traversing the node tree</h1>”
document.write(txt)
set xmlDoc=CreateObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”note.xml”)
for each x in xmlDoc.documentElement.childNodes
document.write(”<b>” & x.nodename & “</b>”)
document.write(”: “)
document.write(x.text)
document.write(”<br>”)
next
</script>
</body>
</html>
装载XML 进入HTML
<html>
<head>
<script language=”JavaScript”
for=”window” event=”onload”>
var xmlDoc = new ActiveXObject(”Microsoft.XMLDOM”)
xmlDoc.async=”false”
xmlDoc.load(”note.xml”)
nodes = xmlDoc.documentElement.childNodes
to.innerText = nodes.item(0).text
from.innerText = nodes.item(1).text
header.innerText = nodes.item(2).text
body.innerText = nodes.item(3).text
</script>
<title>HTML using XML data</title>
</head>
<body bgcolor=”yellow”>
<h1>Refsnes Data Internal Note</h1>
<b>To: </b><span id=”to”></span>
<br>
<b>From: </b><span id=”from”></span>
<hr>
<b><span id=”header”></span></b>
<hr>
<span id=”body”></span>
</body>
</html>
'取得根节点set dom=CreateObject("microsoft.xmldom")dom.async=falsedom.load "c:\user.xml" set book1=rootNode.childNodes(1)book1.ownerDocument 返回Document节点,指向XML文档本身book1.previousSibling 前一个节点book1.parentNode 父节点book1.firstChild 第一个子节点book1.lastChild 最后一个子节点book1.childNodes 子节点集合 '添加节点set node=rootNode.childNodes.item(0)set newNode=myDocument.createElement("publisher")set rtnNode=node.insertBefore(newNode,node.lastChild)set textNode=myDocument.createTextNode("人民邮电出版社")node.childNodes.item(1).appendChild(textNode) '删除节点set node=root.childNodes.item(0)set oldNode=node.removeChild(node.childNodes.item(4)) '修改节点 set node=root.childNodes.item(0)node.nodeValue="158" '常用DOM的方法 createAttribute(属性的名字) 创建一个属性节点。然后可以用setAttributeNode方法把该属性设置为某个元素的属性createCDATASection(内容) 创建一个CDATA节点。createMessage(内容) 创建一个注释节点,值就是参数内容createElement(名字) 创建元素节点createEntityReference(名字) 创建一个实体引用节点,如果被引用的实体是已知的,那么该实体引用节点和相应的实体节点有同样的子节点集createProcessingInstruction(处理指令的目标部分,处理指令的数据部分) 创建一个具有指定名字和数据的处理指令节点createTextNode(内容) 创建一个具有指定内容的文本节点
Node的常用属性 attributeschildNodes 子节点的集合firstChild 第一个子节点 lastChild 最后一个子节点previousSibling 当前节点的前驱节点nextSibling 当前节点的后继节点nodeName 当前节点的名字nodeType 节点类型nodeValue 节点的值parentNodes 父节点
Node方法appendChild(newChild) 添加到所有子节点的最后,返回添加的节点cloneNode(boolean deep) 复制当前节点,复制产生的节点没有父节点,返回复制的节点hasChildNodes 无参数,判断是否有子节点createElement 创建元素节点insertBefore(newChild,refChild) 把节点newChild插入到当前节点的子节点refChild之前。返回插入的节点removeChild(oldChild) 把子节点oldChild删除,并返回oldChild节点。replaceChild(newChild,oldChild) 替换节点,返回被删除的节点 NodeList是动态的,对文档的改变会直接反映到相关的NodeList对象中。
属性:lengthItem(0)-Item(nodeList.length-1) NamedNodeMap包含的节点是无序的。表示节点和唯一名字的对应关系。属性length方法:getNamedItem(name) 返回给定名称的节点item(0...) removeNamedItem(name) 删除给定名称的节点setNamedItem(name) 把给定节点名的节点添加到当前节点集中,如果改名字节点已经存在,替换 ASP通过XMLDom在服务器端操作XML文件的主要方法和实现对于小数据量,xml文件在检索更新上于ACCESS有很多优势。我曾经测试过不用数据库,把网站的会员信息,商品数据信息,交易信息,网站定制信息全部存放在三个xml文件中,运行结果十分正常,感觉上比数据库快多了,不过没有作测试,不能确定。
下面说一下创建,查询,修改等对xml操作的主要方法'创建DOM对象set objDom=server.CreateObject("MicroSoft.XMLDom")'取得xml数据'方法1 取得xml文件的xml数据objDom.load("c:\test.xml")'方法2 取得xml数据串的数据objDom.loadxml("<people><man name="sd"/></people>") '创建一个节点对象Set Newnode=objDom.CreateElement("people")'给这个节点赴值Newnode.Text="人"' 给这个节点添加属性Set NewAttribute=objDom.CreateNode("attribute","name","") NewAttribute.Text= "张三"Newnode.SetAttributeNode NewAttribute'给这个节点添加子节点Set NewnodeChild=objDom.CreateElement("address")Newnode.appendChild NewnodeChild'保存这个节点对象objDom.appendChild NewnodeobjDom.save("c:\test.xml")'查找一个节点对象set objtofind=objdom.documentElement.SelectSingleNode("//people/man")'取出这个节点对象的 节点名,节点值,某个属性值,和全部的xmlnodename=objtofind.nodenamenodevalue=objtofind.textobjtofind.GetAttributeNode("name").Nodevalue ’属性名为name的属性值'取出一个属性节点对象set objattrtofind=objdom.documentElement.SelectSingleNode("//people/man"). GetAttributeNode("name")'取出这个节点的属性名,属性值nodeattrname=objattrtofind.nodenamenodeattrvalue=objattrtofind.nodevalue'删除一个节点对象set objnode=objdom.documentElement.SelectSingleNode("//people/man") ’要删除的节点set objparentnode=objdom.documentElement.SelectSingleNode("//people") ’要删除的节点的父节点objparentnode.removeChild objnode'取出一个节点的字节点集合set objnodes=objdom.documentElement.SelectSingleNode("//people/man").ChildNodes '遍历这个集合'方法1 for each element in objnodesresponse.write element.nodename 字节点名response.write element.text 字节点值 next'方法2domlength=objnodes.lengthfor i = 0 to domlength-1response.write objnodes.childnodes(i).nodename 字节点名response.write objnodes.childnodes(i).text 字节点值next '取出一个节点的属性集合set objnodes=objdom.documentElement.SelectSingleNode("//people/man").GetAttributeNode("name").attributes '遍历这个集合for each element in objnodesresponse.write element.nodename 属性名response.write element.nodevalue 属性值next
- Microsoft.xmldom介绍以及api文档及相关资料
- Microsoft.XMLDOM相关资料
- Microsoft.XMLDOM相关资料
- Microsoft.XMLDOM相关资料
- microsoft.xmldom(一) xml文档遍历js
- microsoft.xmldom
- Microsoft.XMLDOM
- Python 介绍及相关资料
- Python 介绍及相关资料
- Microsoft.XMLDOM组件
- Microsoft.XMLDOM 学习
- Microsoft.XMLDOM 对象详解
- Microsoft.XMLDOM中文手册
- Microsoft.XMLDOM组件
- workqueue及相关API的介绍
- 用vc6操作xml以及xmldom的简单介绍
- 用vc6操作xml以及xmldom的简单介绍
- Microsoft Indexing Service 相关资料
- c++头文件 include保护符
- cookie的使用
- Oracle 实例创建和基础配置指南
- tomcat 7+Apache Solr 3.6 部署
- windows 网络编程经典入门
- Microsoft.xmldom介绍以及api文档及相关资料
- Jdbc事务控制
- vs2010快捷键-- 摘
- 使用expect实现shell的交互
- Aop_面向切面编程(1)_思想理解
- document.body.scrollTop与document.documentElement.scrollTop兼容
- 【设计模式】牛市股票还会亏钱 --- 外观模式
- 由Passbook联想到Path的盈利模式
- 2.8.4 Wi n d o w s字符串函数