用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前面,意图先载入事件.

有四种状态:

  1. DOM正在加载
  2. DOM已经加载完数据
  3. DOM已经可以使用,但某些部分还无法访问
  4. 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);

  1. DOM2级支持基本DOM操作创建xml,但是不支持loadXML()方法,无法简易的通过字符串创建xml文档。
    有load()方法,也不能跨域加载。

    xmlDom.load('demo.xml');

  2. 没有xmlDom.xml序列化,DOM2没有xml序列化方法

  3. 获取标签里面的值,除了

    xmlDom.getElementByTagName('user')[0].firstChild.nodeValue;

    还有

    xmlDom.getElementByTagName('user')[0].textContent;//w3c标准的

  4. 同步异步加载

    xmlDom.async = false;
    xmlDom.load('demo.xml'); //只支持firfox opera

  5. 模拟loadXML()方法,可以简易创建xml字符串

    var xmlParser = new DOMParser(); //创建对象

    var xmlStr = 'Lee';

    var xmlDom = xmlParser.parserFromString(xmlStr,'text/xml');

  6. 模拟.xml属性序列化字符串

    var serializer = new XMLSerializer();

    var xml = serializer.serializeToString(xmlDom);

用javascript操作xml的更多相关文章

  1. JavaScript操作XML

    JavaScript操作XML (一) JavaScript操作XML是通过XML DOM来完成的.那么什么是XML DOM呢?XML DOM 是: 用于 XML 的标准对象模型 用于 XML 的标准 ...

  2. JavaScript操作XML (一)

    JavaScript操作XML是通过XML DOM来完成的.那么什么是XML DOM呢?XML DOM 是: 用于 XML 的标准对象模型 用于 XML 的标准编程接口 中立于平台和语言 W3C 的标 ...

  3. JavaScript操作XML工作记录

    JavaScript操作XML (一) JavaScript操作XML是通过XML DOM来完成的.那么什么是XML DOM呢?XML DOM 是: 用于 XML 的标准对象模型 用于 XML 的标准 ...

  4. JavaScript操作XML(二)

    上一篇介绍了XML的结构以及节点之间的关系这一篇介绍浏览器内建的XML解析器以及JavaScript是如何加载XML的. 大多数浏览器都有读取和操作 XML 的内建 XML 解析器. 解析器(XML ...

  5. 用 javascript 操作 xml

    1. [代码]js代码     <script language="JavaScript"><!--var doc = new ActiveXObject(&qu ...

  6. 用javascript操作xml(二)JavaScript 将XML转换成字符串(xml to string)

    function xmlToString(xmlData) { var xmlString; //IE if (window.ActiveXObject){ xmlString = xmlData.x ...

  7. 用javascript操作xml(三)关于Jquery的html()不兼容IE的解决办法

    当 $("#xxx").html(data); 不兼容,方法替换为 document.getElementById("xxx").innerHTML=data;

  8. 使用JavaScript操作DOM节点元素的常用方法(创建/删除/替换/复制等)

    getElementById(id)这是通过id来访问某一元素,最常用的之一,例:<html><body><div id="myid">test ...

  9. JQuery制作网页—— 第三章 JavaScript操作DOM对象

    1. DOM:Document Object Model(文档对象模型):          DOM操作:                   ●DOM是Document Object Model的缩 ...

随机推荐

  1. jQuery中get与eq的区别

    get与eq的区别 .eq() 减少匹配元素的集合,根据index索引值,精确指定索引对象. .get() 通过检索匹配jQuery对象得到对应的DOM元素. 同样是返回元素,那么eq与get有什么区 ...

  2. Java空字符串与null的区别和判断字符串是否为空的方法

    Java空字符串与null的区别: 1.类型null表示的是一个对象的值,而并不是一个字符串.例如声明一个对象的引用,String a = null ;""表示的是一个空字符串,也 ...

  3. 怎么从代码中拿到栈回溯信息(call stack trace)

    博客搬到了fresky.github.io - Dawei XU,请各位看官挪步.最新的一篇是:怎么从代码中拿到栈回溯信息(call stack trace).

  4. C++ Virtual详解

    转自:http://www.cnblogs.com/xd502djj/archive/2010/09/22/1832912.html Virtual是C++ OO机制中很重要的一个关键字.只要是学过C ...

  5. Recommended add-ons/plugins for Microsoft Visual Studio

    http://stackoverflow.com/questions/2767/recommended-add-ons-plugins-for-microsoft-visual-studio NUGe ...

  6. 监控mysql索引使用效率的脚本

      SELECT  t.table_schema AS db,  t.table_name   AS tab_name,  s.index_name   AS index_name,  s.colum ...

  7. vim的一些高级配置

    今天有幸看到一篇博文,有一些vim的高级配置 在linux或者unix下面的.vimrc文件中,在其中可以添加如下片段,可以实现解释上面你说的那些高级用法 " Ctrl + K 插入模式下光 ...

  8. 导入cocos2d-x samples android官方示例

    导了一晚上samples android示例,查了一晚上资料,费了很大的劲,终于成功导入并运行成功,分享一下经验: 1.下载eclipse与ADT跟android SDK,相信大家都会装了吧. 2.下 ...

  9. c语言,strcspn,在串中查找第一个给定字符集内容的段

    函数名: strcspn 功 能: 在串中查找第一个给定字符集内容的段 用 法: int strcspn(char *str1, char *str2); 程序例: #include <stdi ...

  10. ASP.NET MVC(一) 什么是Razor

    Razor 是一种向网页添加基于服务器的代码的标记语法 Razor 不是编程与语言.它是服务端标记语言. 当网页被写入浏览器时,基于服务器的代码能够创建动态内容.在网页加载时,服务器在向浏览器返回页面 ...