用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. weapon制作武器

    weapon制作武器 (weapon.pas/c/cpp) 解题报告 制作武器weapon.pas/c/cpp) 背景 WZland的紧急避难所很快就建好了,WZland的居民们陆续地来到这个紧急避难 ...

  2. Asp.net 管道事件

    在处理该请求时将由 HttpApplication 类执行以下事件. 希望扩展 HttpApplication 类的开发人员尤其需要注意这些事件. 1. 对请求进行验证,将检查浏览器发送的信息,并确定 ...

  3. eclipse 插件之Code Folding

    功能: eclipse自带折叠包括方法, import, 注释等得折叠功能, code folding 插件对其增强. 1. 下载插件:( 也可以用link方式, 我的是link安装, jar包网上很 ...

  4. 自定义Dictionary支持线程安全

    本文转载:http://www.cnblogs.com/kiddo/archive/2008/09/25/1299089.html 我们说一个数据结构是线程安全指的是同一时间只有一个线程可以改写它.这 ...

  5. preference activity框架

    从android3.0开始preference框架做了重大改变 框架由一下四部分组成 1.preference screen布局 一个xml文件,指定了要显示的Preference控件. 每个控件应当 ...

  6. java18 任务调度

    任务调度; Timer类, /** 了解 Timer() schedule(TimerTask task, Date time) schedule(TimerTask task, Date first ...

  7. How to save/read file on different platforms

    You can use standard c functions, such as fopen, fwrite, to save and read file on different platform ...

  8. 【转】Cocos2d-x 2.x CCSprite 灰白图的生成(利用shader设置)——2013-08-27 21

    猴子原创,欢迎转载.转载请注明: 转载自Cocos2D开发网–Cocos2Dev.com,谢谢! 原文地址: http://www.cocos2dev.com/?p=325 游戏中人物死掉后要把人物头 ...

  9. 【转】cocos2d-x 模仿计时器效果,动态增加分数——2013-08-25 16

    http://www.cocos2dev.com/?p=90 游戏中要用到分数是动态增加的,而不是瞬间加上去的. bool HelloWorld::init() { if ( !CCLayer::in ...

  10. asp遇到的一些问题

    1.伪静态问题...后台设置支持, 2.数据库链接错误,也就是说  .net 功能冲突,要后台关闭 3.本机也可以设置 iis服务器 win7配置自己的IIS服务器亲自做的图文很详细 http://j ...