用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的缩 ...
随机推荐
- Python实现二叉树的前序遍历、中序遍历
计算根节点到叶子节点的所组成的数字(1247, 125, 1367)以及叶子节点到根节点组成的数字(7421, 521, 8631),其二叉树树型结构如下 计算从根节点到叶子节点组成的数字,本质上来说 ...
- 用Regex类计算一个字符串出现次数是最好方法【转载】
我的一个朋友问我,怎么在c#或vb.net中,计算一个字符串中查找另一个字符串中出现的次数,他说在网上打了好多方法,我看了一下,有的是用replace的方法去实现,这种方法不是太好,占资源太大了.其实 ...
- socket编程——一个简单的样例
从一个简单的使用TCP样例開始socket编程,其基本过程例如以下: server client ++ ...
- OpenCV -- 获取轮廓照片
import cv2 img = cv2.imread( 'E:\A.jpeg' ) cv2.imshow( 'img', img ) gray = cv2.cvtColor( img, cv2.CO ...
- 【剑指offer】包括min函数的栈
转载请注明出处:http://blog.csdn.net/ns_code/article/details/26064213 剑指offer上的第21题,之前在Cracking the Coding i ...
- 标准I/O库之打开和关闭流
下列三个函数打开一个标准I/O流. #include <stdio.h> FILE *fopen( const char *restrict pathname, const char *r ...
- [转]HTML5 classList API
Having thrust myself into the world of JavaScript and JavaScript Libraries, I've often wondered: Whe ...
- 打造强大的BaseModel(2):让Model实现自动映射,将字典转化成Model
打造强大的BaseModel(1):让Model自我描述 这篇文章将讲述Model一项更高级也最常用的功能,让Model实现自动映射–将字典转化成Model(所有代码全由Swift实现) 将JSON转 ...
- 关于Servlet中重定向
public class Red1Servlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpSer ...
- Java基础知识强化之IO流笔记39:字符流缓冲流之复制文本文件案例01
1. 字符流缓冲流之复制文本文件案例 需求:把当前项目目录下的a.txt内容复制到当前项目目录下的b.txt中 数据源: a.txt -- 读取数据 -- 字符转换流 -- InputStreamRe ...