fanzhongzhou

JavaScript读取XML文件[兼容IE,FF,Chrome,Safari]

IE读取XML文件
FireFox读取XML文件
Chrome,Safari读取XML文件
以上三类浏览器读取XML文件各有不同,常常困扰开发人员,现在我们将其融合为一个函数方便大家使用。

// 加载XML文件并返回XML文档节点
function loadXmlFile(xmlFile){
  var xmlDom = null;
  if (window.ActiveXObject){
    xmlDom = new ActiveXObject("Microsoft.XMLDOM");
    //xmlDom.loadXML(xmlFile);//如果用的是XML字符串
    xmlDom.load(xmlFile);//如果用的是xml文件。
  }else if (document.implementation && document.implementation.createDocument){
    var xmlhttp = new window.XMLHttpRequest();
    xmlhttp.open("GET", xmlFile, false);
    xmlhttp.send(null);
    xmlDom = xmlhttp.responseXML;
  }else{
    xmlDom = null;
  }
  return xmlDom;
}

将该函数保存入JS文件,引用方式:var xmlDom = loadXmlFile("123.xml");

xmlDom得到的将是整个XHTML节点,接下来就直接按照W3C标准的节点处理方式针对该节点进行所需处理即可。

当前版本兼容IE,FF,Chrome,Safari。

IE读取XML文件
FireFox读取XML文件
Chrome,Safari读取XML文件
以上三类浏览器读取XML文件各有不同,常常困扰开发人员,现在我们将其融合为一个函数方便大家使用。

// 加载XML文件并返回XML文档节点
function loadXmlFile(xmlFile){
  var xmlDom = null;
  if (window.ActiveXObject){
    xmlDom = new ActiveXObject("Microsoft.XMLDOM");
    //xmlDom.loadXML(xmlFile);//如果用的是XML字符串
    xmlDom.load(xmlFile);//如果用的是xml文件。
  }else if (document.implementation && document.implementation.createDocument){
    var xmlhttp = new window.XMLHttpRequest();
    xmlhttp.open("GET", xmlFile, false);
    xmlhttp.send(null);
    xmlDom = xmlhttp.responseXML;
  }else{
    xmlDom = null;
  }
  return xmlDom;
}

将该函数保存入JS文件,引用方式:var xmlDom = loadXmlFile("123.xml");

xmlDom得到的将是整个XHTML节点,接下来就直接按照W3C标准的节点处理方式针对该节点进行所需处理即可。

当前版本兼容IE,FF,Chrome,Safari。

posted on 2011-12-27 14:00 jberry 阅读(1864) 评论(0)  编辑  收藏


只有注册用户登录后才能发表评论。


网站导航:
 
<2011年12月>
27282930123
45678910
11121314151617
18192021222324
25262728293031
1234567

导航

统计

常用链接

留言簿

随笔档案

搜索

最新评论

阅读排行榜

评论排行榜