如何使用javascript解析xml文件.doc
(JavaScript工具函数)JavaScript中的文件读写操作
(JavaScript工具函数)JavaScript中的文件读写操作JavaScript中的文件读写操作JavaScript是一种广泛应用于Web开发的脚本语言,它不仅可以用于处理用户交互,还可以用于在浏览器中进行文件的读写操作。
文件读写操作是开发中经常遇到的需求,本文将介绍JavaScript中的一些工具函数,帮助开发者更方便地进行文件读写操作。
一、文件读取在JavaScript中,文件读取通常使用FileReader对象来实现。
FileReader对象提供了一些方法和事件,用于读取文件的内容。
1. 创建FileReader对象要使用FileReader对象进行文件读取,首先需要创建一个FileReader对象。
可以通过以下方式创建一个新的FileReader对象:```javascriptconst reader = new FileReader();```2. 读取文件在创建FileReader对象之后,可以使用其readAsText()方法来读取文件的内容。
readAsText()方法接受一个参数,即要读取的文件对象。
```javascriptconst fileInput = document.getElementById('fileInput');fileInput.addEventListener('change', handleFile);function handleFile(event) {const file = event.target.files[0];const reader = new FileReader();reader.readAsText(file);}```上述代码中,我们使用addEventListener()方法为fileInput元素添加了一个change事件的监听器。
当用户选择了一个文件后,会触发该事件,并调用handleFile函数。
jsoup解析xml常用方法
一、jsoup简介jsoup是一个用于解析、处理HTML和XML文档的Java库,提供了一系列方便快捷的API,使得解析和操作文档变得非常简单。
在处理XML文档时,jsoup同样具有很高的效率和灵活性。
本文将介绍jsoup解析XML常用方法,希望对读者有所帮助。
二、jsoup解析XML的基本步骤1.导入jsoup库在进行XML解析之前,首先需要导入jsoup库。
可以通过Maven、Gradle等工具将jsoup库添加到项目依赖中,然后即可在代码中引入相关的类和方法。
2.加载XML文档要解析XML文档,首先需要将XML文件加载到jsoup中。
可以使用Jsoup.parse()方法来加载XML文件,该方法允许传入File、URL、String等类型的参数,非常灵活方便。
3.获取XML文档元素加载XML文档后,就可以通过jsoup提供的API来获取XML文档中的各种元素。
可以通过getElementById()、getElementsByTag()等方法来获取指定的元素。
4.遍历XML文档遍历XML文档是解析和处理XML文档的重要步骤。
通过jsoup提供的遍历方法,可以轻松地对XML文档进行遍历,并针对具体需求进行处理。
5.解析XML元素针对XML文档中的具体元素,可以通过jsoup提供的方法来解析并获取其内容、属性等信息。
可以通过text()方法来获取元素的文本内容,attr()方法来获取元素的属性值等。
6.其他操作除了上述基本步骤,jsoup还提供了许多其他针对XML文档的操作方法,如修改元素内容、添加元素、删除元素等,读者可以根据具体需求进行使用。
三、jsoup解析XML的常用方法1.加载XML文档可以使用如下代码来加载XML文档:```File file = new File("example.xml");Document doc = Jsoup.parse(file, "UTF-8", "xxx");```通过上述代码,可以将名为"example.xml"的XML文件加载到jsoup 中,并指定编码格式和基本URL。
java xmldocument类的用法
一、概述Java语言是一种跨评台的面向对象编程语言,被广泛应用于企业级应用程序开发领域。
XML(可扩展标记语言)是一种通用的标记语言,用于描述数据的结构和内容。
在Java中,XMLDocument类被用来表示一个XML文档,可以对XML文档进行创建、解析、修改和验证等操作。
二、XMLDocument类的概述1. XMLDocument类位于org.w3c.dom包中,是DOM(文档对象模型)的一部分。
它表示了整个XML文档的树形结构,包括文档的根节点、元素节点、属性节点、文本节点等。
2. XMLDocument类实现了Document接口,提供了操作XML文档的方法。
三、XMLDocument类的基本用法1. 创建XMLDocument对象可以通过DocumentBuilder类的实例来创建一个空的XMLDocument对象。
首先需要创建一个DocumentBuilder对象,然后使用它来创建一个Document对象。
2. 解析XML文档XMLDocument类提供了方法来解析XML文档,例如通过解析器(如SAX解析器或DOM解析器)解析XML文档,并将其转换为XMLDocument对象。
3. 遍历XML文档XMLDocument类提供了方法来遍历XML文档的节点,例如获取文档的根节点、获取子节点、获取父节点、获取兄弟节点等。
4. 修改XML文档XMLDocument类提供了方法来对XML文档进行修改,例如添加节点、删除节点、修改节点的属性和文本内容等。
5. 验证XML文档XMLDocument类提供了方法来验证XML文档的合法性,例如验证文档的结构、验证文档的数据类型等。
6. 将XMLDocument对象序列化为XML文档XMLDocument类提供了方法来将XMLDocument对象序列化为XML文档的字符串表示,以便于存储或传输。
四、XMLDocument类的示例代码以下是一个简单的示例代码,演示了如何创建一个XMLDocument对象,并对其进行一些基本操作。
js 读取本地 xml
}
//返回XML文档的根元素节点。
return xmlDoc.documentElement;
}
} else{
//针对非IE浏览器
if(document.implementation && document.implementation.createDocument){
return xmlDoc.documentElement;
}
}
}
return null;
}
/**
* 封装装载XML的方法,并返回XML文档的根元素节点。
* @param flag true时参数xml表示xml文档的名称;false时参数xml是一个字符串,其内容是一个xml文档
</question>
</j2eeQuertion>
用法
Js代码
var contentXML = loadXML(true,xmlUrl);
var que = contentXML.getElementsByTagName("question");
for(var i = 0 ; i < que.length ; i++){
} else{
//根据表示XML文档的字符串装载
xmlDoc.loadXML(xml);
}
//返回XML文档的根元素节点。
return xmlDoc.documentElement;
}
} else{
//针对非IE浏览器
if(document.implementation && document.implementation.createDocument){
利用 XMLPullParser 进行XML 数据解析和处理
利用 XMLPullParser 进行XML 数据解析和处理使用XMLPullParser进行XML数据解析和处理XMLPullParser是一种在Android平台上常用的用于解析和处理XML数据的工具。
它具有快速、高效的特点,能够准确地解析XML 文档,并提供了灵活的API来处理解析结果。
本文将介绍如何利用XMLPullParser进行XML数据解析和处理。
一、XML数据解析的概念和原理XML数据解析是指将XML文档中的数据提取出来并进行处理的过程。
XML文档是一种标记语言,用于描述结构化的数据。
XML数据解析的过程可以分为以下几个步骤:1. 创建XMLPullParser对象:首先,需要创建一个XMLPullParser 对象,用于解析XML文档。
2. 设置输入源:在进行XML数据解析之前,需要设置XMLPullParser的输入源。
输入源可以是一个文件、一个输入流或者一个URL。
3. 解析XML文档:通过调用XMLPullParser对象的相应方法,可以逐行解析XML文档,获取XML文档中的节点信息和数据。
4. 处理解析结果:根据XML数据的结构和需要,可以使用条件语句、循环结构等方式对解析结果进行处理,提取所需的数据,并进行后续的操作。
二、利用XMLPullParser进行XML数据解析的步骤下面逐步介绍如何使用XMLPullParser进行XML数据解析和处理的具体步骤。
步骤1:导入相关的类和包在使用XMLPullParser进行XML数据解析之前,需要导入相应的类和包。
具体的导入语句如下:import org.xmlpull.v1.XmlPullParser;import org.xmlpull.v1.XmlPullParserException;import org.xmlpull.v1.XmlPullParserFactory;import java.io.InputStream;步骤2:创建XMLPullParser对象需要通过XmlPullParserFactory类的newInstance()方法创建XmlPullParserFactory对象,并通过XmlPullParserFactory对象的newPullParser()方法创建XMLPullParser对象,示例代码如下:XmlPullParserFactory factory = XmlPullParserFactory.newInstance();XmlPullParser parser = factory.newPullParser();步骤3:设置输入源设置XMLPullParser对象的输入源,可以是一个输入流、一个文件或者一个URL。
docx4j 的xmlutils 解析表格
一、简介docx4j 是一个用于创建和操作 Office Open XML (docx, xlsx, pptx) 文档的开源Java库。
xmlutils 是 docx4j 库中的一个工具类,用于解析和操作xml格式的文件,特别是在处理表格时非常实用。
本文将介绍如何使用 xmlutils 解析表格,并展示一些实际的代码示例。
二、xmlutils 解析表格的基本流程1. 读取 docx 文件使用 docx4j 的工具类加载一个 docx 文件,并将其转换成一个Document 对象。
2. 获取表格信息通过Document 对象,可以获取到其中的表格信息,包括表格的行数、列数,每个单元格的内容等。
3. 解析表格内容使用 xmlutils 工具类,可以逐行、逐列地解析表格中的内容,可以根据需要对表格中的内容进行筛选、处理。
4. 对表格进行操作在解析表格内容的基础上,可以对表格进行一些操作,比如插入新的行、删除指定的列,修改单元格的内容等。
三、使用 xmlutils 解析表格的示例下面是一个简单的示例,演示了如何使用 xmlutils 解析表格内容:```java// 加载 docx 文件WordprocessingMLPackage wordMLPackage = WordprocessingMLPackage.load(new File("example.docx"));M本人nDocumentPart m本人nDocumentPart = wordMLPackage.getM本人nDocumentPart();// 获取所有表格List<Object> tables = m本人nDocumentPart.getContent().get(0).getAllElementFromObject(Tr .TABLE);// 遍历所有表格for (Object table : tables) {Tbl tbl = (Tbl) table;List<Object> rows = XmlUtils.unwrap(tbl).getContent();// 遍历表格的每一行for (Object row : rows) {Tr tr = (Tr) row;List<Object> cells = XmlUtils.unwrap(tr).getContent();// 遍历每一行的每一个单元格for (Object cell : cells) {Tc tc = (Tc) cell;List<Object> texts = tc.getContent();// 输出单元格的内容for (Object text : texts) {if (text instanceof Text) {System.out.println(((Text) text).getValue());}}}}}```上面的示例代码演示了如何使用 xmlutils 解析表格内容,并输出每个单元格的文本内容。
js对xml的解析
var xDoc = null;
if (document.implementation && document.implementation.createDocument) {
xDoc = document.implementation.createDocument("", "", null);
}
catch (e) {
msXmlAx = new ActiveXObject("Msxml.DOMDocument");
}
xDoc = msXmlAx;
}
js对xml的解析。
colordancer 发表于 2006-4-7 22:23:00
1.对XMLHttpRequest请求返回的responseXML进行解析,responseXML是个XMLDOcument对象
假设返回的responseXML为:
<?xml version="1.0" encoding="UTF-8"
} else {
if ((typeof ActiveXObject) != "undefined") {
var msXmlAx = null;
try {
msXmlAx = new ActiveXObject("Msxml2.DOMDocument");
doc.appendChild(peopleElem);
alert(doc.xml);//xml属性只对IE管用
<address street="321 south avenue" city="denver" state="co" country="usa" />
利用javascript实现遍历xml文件的代码实例
利⽤javascript实现遍历xml⽂件的代码实例利⽤⼀个实例来介绍了关于如何利⽤js来遍历xml⽂件的办法,有需要学习的同学可以参考⼀下本实例啊。
<script>function getXmldoc(xmlfile){ //创建Xmldocument对象,使⽤⽅法:传⼊xml⽂件名即可。
var xmlDoc;// 判断浏览器是不是IEif (window.ActiveXObject) {xmlDoc=new ActiveXObject(“Microsoft.XMLDOM”);}// 判断浏览器不是⽕狐及其他浏览器else if (document.implementation && document.implementation.createDocument) {xmlDoc=document.implementation.createDocument(“”,”",null);} else {alert(‘你的浏览器不能处理脚本’);}xmlDoc.async=false; //关闭异步传输xmlDoc.load(xmlfile); //载⼊xml⽂件return(xmlDoc);}var xmldoc=getXmldoc(“cd.xml”); //添加xml⽂件,创建document对象var cds=xmldoc.getElementsByTagName(“cd”); //获得xml⽂件⾥⾯的所有cd标签//alert(cds[0].childNodes[0].childNodes[0].nodeValue); //获得第⼀个cd标签⾥的第⼀个title标签⾥⾯的第⼀个⽂本节点的内容var str=’<table border=”1″ width=”500″ align=”center”>’;//遍历xml⽂件内容,以表格形式输出for(var i=0; i<cds.length; i++){str+=”<tr>”;for(var j=0; j<cds[i].childNodes.length; j++){if(cds[i].childNodes[j].nodeType==1){ //判断节点类型,因为IE和⽕狐两个浏览器获取xml⽂件不⼀样,换⾏也会当做⼀个节点str+=’<td>’+cds[i].childNodes[j].childNodes[0].nodeValue+’</td>’;}}str+=’</tr>’;}str+=’</table>’;</script><div id=“one” style=”background:#ccc“></div><script>document.getElementById(“one”).innerHTML=str; //输出内容</script>。
xml2js同步方法
xml2js同步方法
对于xml2js库,它主要用于将XML数据转换为JavaScript对象。
在xml2js中,通常使用parseStringSync方法来同步解析XML 数据。
这个方法会将XML数据解析为JavaScript对象,而不需要使用回调函数来处理结果。
要使用parseStringSync方法,首先需要引入xml2js库,然后创建一个解析器对象。
接着,可以调用parseStringSync方法并传入要解析的XML数据作为参数。
解析完成后,可以直接使用返回的JavaScript对象进行后续操作。
需要注意的是,由于parseStringSync方法是同步的,所以在解析大型XML文件时可能会导致阻塞。
因此,建议在处理大型XML 文件时使用parseString方法,它是xml2js中的异步解析方法,可以避免阻塞主线程。
总之,xml2js库提供了parseStringSync方法来同步解析XML 数据,但在处理大型XML文件时需要注意可能的阻塞情况。
希望这个回答能够帮助你理解xml2js库中的同步解析方法。
js2xmlparser 用法
一、什么是js2xmlparserjs2xmlparser是一个可以将JavaScript对象转换为XML字符串的工具。
通过使用js2xmlparser,用户可以方便地将JavaScript对象转换为符合XML规范的字符串,实现数据的格式转换和传输。
二、 js2xmlparser的安装1. 在Node.js环境下,可以通过npm进行安装:```npm install js2xmlparser```2. 在浏览器环境下,可以通过引入js2xmlparser的CDN信息进行使用:```<script src="xxx"></script>```三、 js2xmlparser的基本用法1. 将JavaScript对象转换为XML字符串:```javascriptconst js2xmlparser = require("js2xmlparser");const obj = {name: "John",age: 30};const xmlString = js2xmlparser.parse("person", obj); console.log(xmlString);```以上代码将输出如下格式的XML字符串:```xml<person><name>John</name><age>30</age></person>```2. 自定义XML节点属性和命名空间:```javascriptconst js2xmlparser = require("js2xmlparser"); const obj = {'': { 'xmlns': 'xxx },p: 'Hello, World!'};const xmlString = js2xmlparser.parse("div", obj); console.log(xmlString);```以上代码将输出如下格式的XML字符串:```xml<div xmlns="xxx"><p>Hello World!</p></div>```四、 js2xmlparser的高级用法1. 使用命令行参数配置js2xmlparser:```javascriptconst js2xmlparser = require("js2xmlparser");const options = {declaration: {include: true},format: {doubleQuotes: true}};const obj = {name: "John",age: 30};const xmlString = js2xmlparser.parse("person", obj, options); console.log(xmlString);```2. 将XML字符串转换为JavaScript对象:```javascriptconst js2xmlparser = require("js2xmlparser");const xmlString ="<person><name>John</name><age>30</age></person>"; const obj = js2xmlparser.parse(xmlString);console.log(obj);```五、 js2xmlparser常见问题解决1. js2xmlparser版本更新问题:及时关注js2xmlparser的冠方文档和更新日志,以了解最新版本的变化和新增功能。
xml文件解析方法
xml文件解析方法XML文件解析方法引言:XML(可扩展标记语言)是一种用于存储和传输数据的标记语言,它具有良好的可读性和灵活性,被广泛应用于数据交换和配置文件等领域。
在处理XML文件时,解析是必不可少的环节。
本文将介绍几种常用的XML文件解析方法,包括DOM、SAX和StAX。
一、DOM解析方法DOM(文档对象模型)是一种将整个XML文件以树形结构加载到内存中的解析方法。
DOM解析器将XML文件解析为一个树状结构,通过遍历节点来获取和操作XML文件中的数据。
DOM解析方法的优点是易于理解和使用,可以随机访问XML文件中的任意节点,但缺点是占用内存较大,不适用于大型XML文件的解析。
1. 创建DOM解析器对象:使用标准的Java API,可以通过DocumentBuilderFactory类来创建DOM解析器对象。
2. 加载XML文件:通过DOM解析器对象的parse()方法加载XML文件,将其转化为一个树形结构。
3. 遍历节点:使用DOM解析器对象提供的方法,如getElementsByTagName()、getChildNodes()等,可以遍历XML文件中的各个节点,获取节点的名称、属性和文本内容等信息。
4. 获取节点数据:通过节点对象提供的方法,如getNodeName()、getTextContent()等,可以获取节点的名称和文本内容。
二、SAX解析方法SAX(简单API for XML)是一种基于事件驱动的XML解析方法。
在SAX解析过程中,解析器顺序读取XML文件,当遇到节点开始、节点结束或节点文本等事件时,会触发相应的回调方法。
相比于DOM 解析方法,SAX解析方法具有内存占用小、解析速度快的优点,但缺点是无法随机访问XML文件中的节点。
1. 创建SAX解析器对象:使用标准的Java API,可以通过SAXParserFactory类来创建SAX解析器对象。
2. 实现事件处理器:自定义一个事件处理器,实现SAX解析器提供的DefaultHandler类,并重写相应的回调方法,如startElement()、endElement()和characters()等。
java xml格式返回报文解析
java xml格式返回报文解析Java中可以使用多种方式解析XML格式的返回报文,常见的方式有DOM解析、SAX解析以及基于XML绑定技术的解析。
每种方式都有不同的特点和适用场景,下面将详细介绍这三种解析方式。
1. DOM解析:DOM(Document Object Model)解析是将整个XML文档加载到内存中,构建成一个树形结构,并提供API来操作这个树。
DOM解析提供了许多API,可以通过节点遍历和搜索、属性读取和设置、节点创建和删除等方式来处理XML文档。
DOM解析适用于对XML文档进行多次读写操作,如增删改查等复杂的操作。
使用Java的DOM解析,可以通过以下几个步骤实现:1)使用DocumentBuilderFactory创建一个DocumentBuilder对象。
2)调用DocumentBuilder的parse方法,传入XML文件的输入流,将XML文档解析为一个Document对象。
3)通过Document对象可以获取XML文档的根元素,从而开始对XML文档进行遍历和操作。
DOM解析的优点是能够将整个XML文档加载到内存中,便于操作和修改。
但是对于较大的XML文件,DOM解析会消耗大量的内存空间。
2. SAX解析:SAX(Simple API for XML)解析是一种基于事件驱动的解析方式,它逐行读取XML文档并触发相应的事件,应用程序根据事件的发生来处理XML文档。
SAX解析的特点是速度快、内存消耗小,适用于对XML文档进行单次顺序读取的操作。
使用Java的SAX解析,可以通过以下几个步骤实现:1)定义一个继承自DefaultHandler的处理器类,重写相应的事件回调方法。
2)使用SAXParserFactory创建一个SAXParser对象。
3)调用SAXParser的parse方法,传入XML文件的输入流和处理器对象,开始解析XML文档。
SAX解析的优点是速度快,内存消耗小,适用于大型XML文件的解析。
JavaScript获取XML文档数据
JavaScript获取XML文档数据
XML文档可以在不同的计算机之间进行传递,如从服务器端传递到客户端。
如果要使用XML文档中的数据进行操作,只需要使用JavaScript程序或其他程序将XML文档中的数据提取出来,并进行操作。
现在创建一个案例,演示使用JavaScript获取XML文档中的数据。
将上述代码保存,名称为DOM.html。
直接单击该网页,会显示如图8-7所示窗口:
图8-7 遍历XML文档
针对不同的浏览器,这里创建XML DOM对象采用了两种方式,一种是以IE 浏览器的方式创建,一种是以其他浏览器方式创建。
XML DOM对象doc创建完成后,使用语句doc.documentElement创建根节点对象x,利用属性ChildNodes获取该对象的子节点集合,并结合length属性、nodeName属性和nodeValue将text中的
节点和数据输出。
xml文件解析流程
xml文件解析流程下载温馨提示:该文档是我店铺精心编制而成,希望大家下载以后,能够帮助大家解决实际的问题。
文档下载后可定制随意修改,请根据实际需要进行相应的调整和使用,谢谢!并且,本店铺为大家提供各种各样类型的实用资料,如教育随笔、日记赏析、句子摘抄、古诗大全、经典美文、话题作文、工作总结、词语解析、文案摘录、其他资料等等,如想了解不同资料格式和写法,敬请关注!Download tips: This document is carefully compiled by theeditor. I hope that after you download them,they can help yousolve practical problems. The document can be customized andmodified after downloading,please adjust and use it according toactual needs, thank you!In addition, our shop provides you with various types ofpractical materials,such as educational essays, diaryappreciation,sentence excerpts,ancient poems,classic articles,topic composition,work summary,word parsing,copy excerpts,other materials and so on,want to know different data formats andwriting methods,please pay attention!1. 读取 XML 文件使用合适的编程语言或工具打开 XML 文件。
JavaScript中的文件读写操作
JavaScript中的文件读写操作JavaScript作为一种脚本语言,广泛用于前端开发和后端开发的Web应用程序中。
除了能够与用户交互,操作DOM元素,处理表单数据等,它还具备操作文件的能力。
本文将介绍JavaScript中的文件读写操作,帮助读者了解如何在JavaScript中实现读取和写入文件。
1. 读取文件在JavaScript中,我们可以使用FileReader对象来读取文件。
以下是读取文件的基本步骤:1. 创建一个FileReader对象:可以使用构造函数`new FileReader()`来创建一个FileReader对象。
2. 使用FileReader的`readAsText()`方法读取文件内容:通过调用FileReader对象的`readAsText()`方法,将文件内容读取为文本。
3. 注册load事件监听器:使用FileReader对象的`onload`事件监听器来处理文件读取完成后的操作。
下面是一个简单的示例:```javascript// 创建FileReader对象var reader = new FileReader();// 注册load事件监听器reader.onload = function(e) {// 文件读取完成后的操作var contents = e.target.result;console.log(contents);}// 读取文件reader.readAsText(file); // file是一个File类型的对象,代表要读取的文件```上述示例中,通过调用`readAsText()`方法将文件内容读取为文本,并在`onload`事件中打印文件内容。
2. 写入文件除了读取文件,JavaScript也可以实现将数据写入文件。
但是需要注意的是,JavaScript本身是运行在浏览器环境中的,无法直接操作本地文件系统。
在Web应用程序中,我们可以借助服务器端的接口来实现文件写入操作。
js domparser解析xml例子
一、介绍DOMParser在JavaScript中,DOMParser是一个用来解析XML或HTML文档的API。
它允许我们将字符串形式的XML文档转换成一个可以被JavaScript代码操作的Document对象。
DOMParser提供了一种简便的方式来处理XML数据,使得我们可以轻松地通过JavaScript来操作和管理XML文档。
二、DOMParser的基本用法我们可以通过以下代码来创建一个新的DOMParser实例:```javascriptvar parser = new DOMParser();```我们可以使用parser.parseFromString()方法来将一个XML字符串解析成一个Document对象:```javascriptvar xmlString = '<bookstore><book><title>JavaScript编程</title><author>John Doe</author></book></bookstore>'; var xmlDoc = parser.parseFromString(xmlString, "text/xml");```这段代码中,我们首先创建了一个XML字符串,并且使用parseFromString()方法将其解析成一个Document对象。
现在,xmlDoc就是一个包含了XML文档结构的Document对象,我们可以通过JavaScript来操作它。
三、使用DOMParser解析XML的例子接下来,让我们通过一个例子来演示如何使用DOMParser来解析XML文档。
假设我们有以下的XML文档:```xml<bookstore><book category="编程"><title lang="en">JavaScript编程</title><author>John Doe</author><year>2022</year></book><book category="科幻"><title lang="en">The Hitchhiker's Guide to the Galaxy</title> <author>Douglas Adams</author><year>1979</year></book></bookstore>```现在我们想要使用DOMParser来解析这个XML文档,并获取其中的书籍信息。
java解析xml详解及示例
java解析xml详解及示例java 解析xml的几种方法第一种:DOMDOM的全称是Document Object Model,也即文档对象模型。
在应用程序中,基于DOM 的XML分析器将一个XML文档转换成一个对象模型的集合(通常称DOM树),应用程序正是通过对这个对象模型的操作,来实现对XML文档数据的操作。
通过DOM接口,应用程序可以在任何时候访问XML文档中的任何一部分数据,因此,这种利用DOM接口的机制也被称作随机访问机制。
DOM接口提供了一种通过分层对象模型来访问XML文档信息的方式,这些分层对象模型依据XML的文档结构形成了一棵节点树。
无论XML文档中所描述的是什么类型的信息,即便是制表数据、项目列表或一个文档,利用DOM所生成的模型都是节点树的形式。
也就是说,DOM强制使用树模型来访问XML文档中的信息。
由于XML本质上就是一种分层结构,所以这种描述方法是相当有效的。
DOM树所提供的随机访问方式给应用程序的开发带来了很大的灵活性,它可以任意地控制整个XML文档中的内容。
然而,由于DOM 分析器把整个XML文档转化成DOM树放在了内存中,因此,当文档比较大或者结构比较复杂时,对内存的需求就比较高。
而且,对于结构复杂的树的遍历也是一项耗时的操作。
所以,DOM分析器对机器性能的要求比较高,实现效率不十分理想。
不过,由于DOM分析器所采用的树结构的思想与XML 文档的结构相吻合,同时鉴于随机访问所带来的方便,因此,DOM分析器还是有很广泛的使用价值的。
Java代码import java.io.File;import javax.xml.parsers.DocumentBuilder;import javax.xml.parsers.DocumentBuilderFactory;import org.w3c.dom.Document;import org.w3c.dom.Element;import org.w3c.dom.NodeList;public class DomT est1{public static void main(String[] args) throws Exception{// step 1: 获得dom解析器工厂(工作的作用是用于创建具体的解析器)DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();// System.out.println("class name: " + dbf.getClass().getName());// step 2:获得具体的dom解析器DocumentBuilder db = dbf.newDocumentBuilder();// System.out.println("class name: " + db.getClass().getName());// step3: 解析一个xml文档,获得Document对象(根结点)Document document = db.parse(new File("candidate.xml"));NodeList list = document.getElementsByTagName("PERSON");for(int i = 0; i < list.getLength(); i++){Element element = (Element)list.item(i);String content =element.getElementsByTagName("NAME").item(0).getFirstC hild().getNodeValue();System.out.println("name:" + content);content =element.getElementsByTagName("ADDRESS").item(0).getFir stChild().getNodeValue(); System.out.println("address:" + content);content =element.getElementsByTagName("TEL").item(0).getFirstChil d().getNodeValue();System.out.println("tel:" + content);content =element.getElementsByTagName("FAX").item(0).getFirstChil d().getNodeValue();System.out.println("fax:" + content);content =element.getElementsByTagName("EMAIL").item(0).getFirstC hild().getNodeValue();System.out.println("email:" + content);System.out.println("--------------------------------------");}}}Java代码import java.io.File;import javax.xml.parsers.DocumentBuilder;import javax.xml.parsers.DocumentBuilderFactory;import org.w3c.dom.Attr;import /doc/723478280.html,ment;import org.w3c.dom.Document;import org.w3c.dom.Element;import/doc/723478280.html,dNodeMap;import org.w3c.dom.Node;import org.w3c.dom.NodeList;/*** 使用递归解析给定的任意一个xml文档并且将其内容输出到命令行上* @author*/public class DomT est3{public static void main(String[] args) throws Exception{DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();DocumentBuilder db = dbf.newDocumentBuilder();Document doc = db.parse(new File("student.xml"));//获得根元素结点Element root = doc.getDocumentElement();parseElement(root);}private static void parseElement(Element element){String tagName = element.getNodeName();NodeList children = element.getChildNodes();System.out.print("<" + tagName);//element元素的所有属性所构成的NamedNodeMap对象,需要对其进行判断 NamedNodeMap map = element.getAttributes();//如果该元素存在属性if(null != map){{//获得该元素的每一个属性Attr attr = (Attr)map.item(i);String attrName = attr.getName();String attrValue = attr.getValue();System.out.print(" " + attrName + "=\"" + attrValue + "\""); } }System.out.print(">");for(int i = 0; i < children.getLength(); i++){Node node = children.item(i);//获得结点的类型short nodeType = node.getNodeType();if(nodeType == Node.ELEMENT_NODE){//是元素,继续递归parseElement((Element)node);}else if(nodeType == Node.TEXT_NODE){//递归出口System.out.print(node.getNodeValue());}else if(nodeType == /doc/723478280.html,MENT_NODE) {System.out.print("System.out.print(data);System.out.print("-->");}}System.out.print("");}}第二种 sax:SAX的全称是Simple APIs for XML,也即XML简单应用程序接口。
JavaScript加载XML文件浏览器兼容性问题解决办法
在自动化测试平台开发过程中,需要将测试用例文件夹目录的树状结构生成xml文件,并将用例路径保存的xml属性中,便于选中用例后寻找执行路径。
因此需要在html中解析xml文件。
解析的方法使用的是js来解析XML文件,并将解析后的XML Dom对象返回。
由于各种浏览器支持Dom对象的方法不同,导致加载xml文件时不同浏览器会弹出各种错误提示。
例如:1.ie的方法错误可能会报:对象不支持此属性或方法2.firefox的方法错误可能会报:ActiveXObject is not defined3.chrome的方法错误可能会报:object #<Document> has no method 'load'本文主要解决在解析XML文件前个各浏览器对XML文件的装载兼容性问题。
在平台中,开始由于少写了Chrome部分的try catch代码,导致在chrome下报错,无法显示配置测试任务页的用例列表,问题在于chrome浏览器不支持load方法(xmlDoc.load(xmlUrl)处抛出异常),需要添加如下代码:var chromeXml = new XMLHttpRequest();chromeXml.open("GET", xmlUrl, false);chromeXml.send(null);xmlDoc = chromeXml.responseXML.documentElement;下面为修改好后的完整js代码,仅供参考function loadXMLDoc(xmlUrl){try //Internet Explorer{xmlDoc=new ActiveXObject("Microsoft.XMLDOM");}catch(e){try //Firefox, Mozilla, Opera, etc.{xmlDoc=document.implementation.createDocument("","",null);}catch(e) {alert(e.message)}}try{xmlDoc.async=false;xmlDoc.load(xmlUrl);}catch(e) {try //Google Chrome{var chromeXml = new XMLHttpRequest();chromeXml.open("GET", xmlUrl, false);chromeXml.send(null);xmlDoc = chromeXml.responseXML.documentElement;//alert(xmlDoc.childNodes[0].nodeName);//return xmlDoc;}catch(e){alert(e.message)}}return xmlDoc;}修改后列表显示正常:欢迎大家登录http://10.22.198.107 (用户名密码:test/test)查看“配置测试任务”页解析xml生成的表格。
JS解析XML文件和XML字符串详解
JS解析XML⽂件和XML字符串详解JS解析XML⽂件<script type='text/javascript'>loadXML = function(xmlFile){var xmlDoc=null;//判断浏览器的类型//⽀持IE浏览器if(!window.DOMParser && window.ActiveXObject){var xmlDomVersions = ['MSXML.2.DOMDocument.6.0','MSXML.2.DOMDocument.3.0','Microsoft.XMLDOM'];for(var i=0;i<xmlDomVersions.length;i++){try{xmlDoc = new ActiveXObject(xmlDomVersions[i]);break;}catch(e){}}}//⽀持Mozilla浏览器else if(document.implementation && document.implementation.createDocument){try{/* document.implementation.createDocument('','',null); ⽅法的三个参数说明* 第⼀个参数是包含⽂档所使⽤的命名空间URI的字符串;* 第⼆个参数是包含⽂档根元素名称的字符串;* 第三个参数是要创建的⽂档类型(也称为doctype)*/xmlDoc = document.implementation.createDocument('','',null);}catch(e){}}else{return null;}if(xmlDoc!=null){xmlDoc.async = false;xmlDoc.load(xmlFile);}return xmlDoc;}</script>JS解析XML字符串<script type='text/javascript'>loadXML = function(xmlString){var xmlDoc=null;//判断浏览器的类型//⽀持IE浏览器if(!window.DOMParser && window.ActiveXObject){ //window.DOMParser 判断是否是⾮ie浏览器var xmlDomVersions = ['MSXML.2.DOMDocument.6.0','MSXML.2.DOMDocument.3.0','Microsoft.XMLDOM'];for(var i=0;i<xmlDomVersions.length;i++){try{xmlDoc = new ActiveXObject(xmlDomVersions[i]);xmlDoc.async = false;xmlDoc.loadXML(xmlString); //loadXML⽅法载⼊xml字符串break;}catch(e){}}}//⽀持Mozilla浏览器else if(window.DOMParser && document.implementation && document.implementation.createDocument){try{/* DOMParser 对象解析 XML ⽂本并返回⼀个 XML Document 对象。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
使用JavaScript解析xml文件或xml格式字符串
javascript中,不论是解析xml文件,还是xml格式的字符串,都是通过DOM对象来进行操作的。
假定xml格式字符串为xmlStr,首先加载xml
// 我们假定不知道客户端使用的浏览器,所以对于XMLDom的创建,尽量满足多浏览器的环境
var xmlDoc;
//如果ie 此判断和下面其他浏览器的判断可以忽略,此处只为说明代码
if (window.ActiveXObject) {
// 由于不知道ie的版本,尽量保持程序的兼容性
var ARR_ACTIVEX =
["MSXML4.DOMDocument","MSXML3.DOMDocument","MSXML2.DOMDocument","MSXM L.DOMDocument","Microsoft.XmlDom"];
// XMLDOM是否创建成功的标志
var XmlDomflag = false;
for (var i =0;i < ARR_ACTIVEX.length &&!XmlDomflag ;i++) { try {
// 尝试创建对象,如果不能正常创建,它会抛出一个错误
var objXML =new ActiveXObject(ARR_ACTIVEX[i]);
// 如果程序能运行到这里,则说明XMLDom对象已经成功创建,所以保存
xmlDoc = objXML;
XmlDomflag = true;
} catch (e) {
}
}
if (xmlDoc) {
xmlDoc.async = false;
// 加载xml,如果是xml文件的话则调用load(xmlFile)
xmlDoc.loadXML(xmlStr);
} else {
return;
}
} else if (document.implementation &&
document.implementation.createDocument) { // 判断是不是遵从标准的浏览器
// 建立DOM对象的标准方法
xmlDoc = document.implementation.createDocument('', '', null); xmlDoc.loadXML(xmlStr);
} else {
// 进这里我也没辙了
return;
}
XMLDOM对象出来了,接下来便是对Dom的操作部分,随便写一个xml字符串简单举个例子:
var xml;
xml ='<?xml version="1.0" encoding="GB2312"?><Output><Field id ="return" text ="111">0</Field><Field id ="errMsg" text ="信息">成功</Field><Field id ="state" text ="状态字">无</Field><DataArea id ="D00E00" text ="参保人员基本信息"><Field id ="EMPNO" text ="编号
"></Field><Field id ="ICNO" text ="IC卡号
"></Field></DataArea></Output>';
经过上面的。
加载进来后
// 加载进来地xml~~
var temp = xmlDoc.xml;
// 取得所有Field 元素
var elementList;
elementList = xmlDoc.getElementsByTagName('Field');
// 遍历
for (var j =0;j < elementList.length; j++) {
var value;
// 取得当前元素属性id的值
value = elementList[j].getAttribute('id');
alert(value);
// 可以设定当前元素属性id的值
elementList[j].setAttribute('id','ooo');
var childs;
// 当前元素的子节点
childs = list[j].childNodes;
// 如果没有子节点(<tagName>...</tagName>间没有任何值)就不能取子节点,否则会出错。
比如id是ICNO的那个元素
if (childs.length >0) {
// childs[0]是第一个当然就代表当前元素的值了,nodeValue可以取得这个节点的值。
alert(childs[0].nodeValue);
}
}。