用javascript操作xml
用javascript操作xml
可以使用标准DOM操作。
IE创建XML MSXML2.0DOMDocument
function createXMLDOM(){
var version = [
'MSXML2.0DOMDocument6.0',
'MSXML2.0DOMDocument3.0',
'MSXML2.0DOMDocument'
];
for (var i = 0; i < version.length; i++) {
try{
var xmlDom = new ActiveXObject(version[i]);
return xmlDom;
}catch(e){
//跳过 有一个错了
}
}
throw new Error("您的系统或者浏览器不支持XML库"); //所有的都错了
}
加载xml字符串 loadXML
xmlDom.loadXML('\nLee\n');
加载外部xml load
xmlDom.load('demo.xml'); //其他的操作一样,用xmlDom.
序列化xml xml
xmlDom.xml //alert(xmlDom.xml);
获取标签 getElementsByTagName('user')[0];
var user = xmlDom.getElementsByTagName('user')[0]; //alert(user);
获取节点类型 nodeType
user.nodeType;
获取节点名 nodeName TagName
user.nodeName;
获取节点内值 (不能用innerHTML,因为innerHTML它不是标准DOM)
user.firstChild.nodeValue;
创建标签 createElement();
var b = xmlDom.createElement('bbb');
获取根节点 documentElement
var root = xmlDom.documentElement;
添加节点 appendChild
root.appendChild(b);
创建节点文本 createTextNode();
var bText = xmlDom.createTextNode('kkk');
b.appendChild(bText);
IE服务器端同步和异步使用XML async
无法跨域加载。
在服务器端默认使用的是异步加载。
无法读取打印文件内容。
1、在服务器端,使用的异步加载,load()还没有加载完毕,就去打印。
使用同步加载
xmlDom.async = false; //同步是false,异步是true
使用同步请求超时,容易造成浏览器假死。
推荐使用异步,但是无法加载打印。使用 onreadystatechange
这个事件需写在load前面,意图先载入事件.
有四种状态:
- DOM正在加载
- DOM已经加载完数据
- DOM已经可以使用,但某些部分还无法访问
- DOM已经完全可以用
用readyState可以获取就绪状态值。
xmlDom.onreadystatechange = function(){
if(xmlDom.readyState == 4)
alert(xmlDom.xml);
}
}
xmlDom.load('demo.xml');
错误提示 parseError errorCode
xmlDom.onreadystatechange = function(){
if(xmlDom.readyState == 4)
if(xmlDom.parseError.eerorCode == 0){
alert(xmlDom.xml);
}else{
throw new Error('错误行号:'+xmlDom.parseError.line+
'\n错误代码:'+xmlDom.parseError.errorCode+
'\n错误解释:'+xmlDom.parseError.reason);
}
}
}
xmlDom.load('demo.xml');
DOM2级XML
创建XML document.implementation.createDocument('','root','');
//第一个参数命名空间,第二个参数xml根标签,第三个参数文档申明null
var xmlDom = document.implementation.createDocument('','root','');
alert(xmlDom);
DOM2级支持基本DOM操作创建xml,但是不支持loadXML()方法,无法简易的通过字符串创建xml文档。
有load()方法,也不能跨域加载。xmlDom.load('demo.xml');
没有xmlDom.xml序列化,DOM2没有xml序列化方法
获取标签里面的值,除了
xmlDom.getElementByTagName('user')[0].firstChild.nodeValue;
还有
xmlDom.getElementByTagName('user')[0].textContent;//w3c标准的
同步异步加载
xmlDom.async = false;
xmlDom.load('demo.xml'); //只支持firfox opera模拟loadXML()方法,可以简易创建xml字符串
var xmlParser = new DOMParser(); //创建对象
var xmlStr = 'Lee';
var xmlDom = xmlParser.parserFromString(xmlStr,'text/xml');
模拟.xml属性序列化字符串
var serializer = new XMLSerializer();
var xml = serializer.serializeToString(xmlDom);
用javascript操作xml的更多相关文章
- JavaScript操作XML
JavaScript操作XML (一) JavaScript操作XML是通过XML DOM来完成的.那么什么是XML DOM呢?XML DOM 是: 用于 XML 的标准对象模型 用于 XML 的标准 ...
- JavaScript操作XML (一)
JavaScript操作XML是通过XML DOM来完成的.那么什么是XML DOM呢?XML DOM 是: 用于 XML 的标准对象模型 用于 XML 的标准编程接口 中立于平台和语言 W3C 的标 ...
- JavaScript操作XML工作记录
JavaScript操作XML (一) JavaScript操作XML是通过XML DOM来完成的.那么什么是XML DOM呢?XML DOM 是: 用于 XML 的标准对象模型 用于 XML 的标准 ...
- JavaScript操作XML(二)
上一篇介绍了XML的结构以及节点之间的关系这一篇介绍浏览器内建的XML解析器以及JavaScript是如何加载XML的. 大多数浏览器都有读取和操作 XML 的内建 XML 解析器. 解析器(XML ...
- 用 javascript 操作 xml
1. [代码]js代码 <script language="JavaScript"><!--var doc = new ActiveXObject(&qu ...
- 用javascript操作xml(二)JavaScript 将XML转换成字符串(xml to string)
function xmlToString(xmlData) { var xmlString; //IE if (window.ActiveXObject){ xmlString = xmlData.x ...
- 用javascript操作xml(三)关于Jquery的html()不兼容IE的解决办法
当 $("#xxx").html(data); 不兼容,方法替换为 document.getElementById("xxx").innerHTML=data;
- 使用JavaScript操作DOM节点元素的常用方法(创建/删除/替换/复制等)
getElementById(id)这是通过id来访问某一元素,最常用的之一,例:<html><body><div id="myid">test ...
- JQuery制作网页—— 第三章 JavaScript操作DOM对象
1. DOM:Document Object Model(文档对象模型): DOM操作: ●DOM是Document Object Model的缩 ...
随机推荐
- 权限管理(java+struts2(自定义标签)实现)--------->全代码演示
地址:http://blog.chinaunix.net/uid-24343152-id-3673026.html 最近由于项目不是很紧所以总结了之前做了n遍的权限管理功能.以便之后系统copy之用. ...
- 最火的Android开源项目(二)
在<直接拿来用!最火的Android开源项目(一)>中,我们详细地介绍了GitHub上最受欢迎的TOP20 Android开源项目,引起了许多读者的热议,作为开发者,你最常用的是哪些开源项 ...
- eclipse项目出现红色叉叉解决方案
方法一:导入的文件被删除了.解决方法:右击项目名,在弹出的菜单中选择“Bulid Path”-->“configure build path”-->“Source”,找到已被删除的那个文件 ...
- @RenderBody()和@RenderSection()
强大的Razor引擎 一.Razor基础简介 Razor采用了cshtml后缀的文件名,截图如下: A. 版面布局 从图上看到,新的视图引擎已经没有了Site.Master这种MasterPage了, ...
- 同步窗体移动 FormMove
方法2 unit Unit1;interfaceuses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, Sy ...
- javascript网页弹出层练习
网页中经常出现很多"popup"弹窗效果,这里做一个练习,给我们初学者一个参考. HTML代码: <div id="popup"></div& ...
- VS C# 快捷键
解决VS2010中工具箱的的不见的问题:按快捷键Ctrl+Alt+X 全屏:Shift+Alt+Enter注释选定内容:Ctrl+E+C/Crtr+E+U代码格式化:ctrl+E+F ======== ...
- 动作之CCActionInstant(立即动作)家族
立即动作就是不需要时间,马上就完成的动作.立即动作的共同基类是CCActionInstant.CCActionInstant的常用子类有: CCCallFunc:回调函数包装器 CCFlipX:X轴翻 ...
- apache solr简单搭建
首先,下载位置是:http://lucene.apache.org/solr/downloads.html 官网的学习资料:http://lucene.apache.org/solr/quicksta ...
- UISenior之数据的本地化持久化
数据的本地化主要分为两个方面:1.简单数据的本地持久化(NSString.NSArray.NSDictionary.NSData)2.复杂数据的本地持久化(本文以Person类为例) 简单对象的本地化 ...