js 解析xml

来源:互联网 发布:网络交易平台可信吗 编辑:程序博客网 时间:2024/05/22 04:27

 最近一个项目中要用到树形列表,本来是用mztree的,但数据用了xml,本来xml就是树形目录,就打算用JavaScript直接解析xml文件了,网上找到一些JavaScript操作xml的方法,在此做一个总结。

  我的xml文件Login.xml如下:

+展开
-XML

<Login>
<Character>
<C Text="热血Value="0">C>
<C Text="弱气Value="1">C>
<C Text="激情Value="2">C>
<C Text="冷静Value="3">C>
<C Text="冷酷Value="4">C>
Character>
<Weapon>
<W Text="光束剑Value="0">W>
<W Text="光束配刀Value="1">W>
Weapon>
<EconomyProperty>
<P Text="平均型Value="0">P>
<P Text="重视攻击Value="1">P>
<P Text="重视敏捷Value="2">P>
<P Text="重视防御Value="3">P>
<P Text="重视命中Value="4">P>
EconomyProperty>
Login>



 现在我需要对这个xml文件的内容进行操作。

  首先,我们需要加载这个xml文件,JavaScript中加载xml文件,是通过XMLDOM来进行的:

+展开
-JavaScript
// 加载xml文档
loadXML = function(xmlFile)
{
var xmlDoc;
if(window.ActiveXObject)
{
xmlDoc = new ActiveXObject('Microsoft.XMLDOM');
xmlDoc.async = false;
xmlDoc.load(xmlFile);
}
else if (document.implementation&&document.implementation.createDocument)
{
xmlDoc = document.implementation.createDocument(''''null);
xmlDoc.load(xmlFile);
}
else
{
return null;
}
return xmlDoc;
}



  xml文件对象出来了, 接下去我就要对这个文档进行操作了。

  比如说,我们现在需要得到节点Login/Weapon/W的第一个节点的属性,那么我们可以如下进行:

+展开
-JavaScript
// 首先对xml对象进行判断
checkXMLDocObj = function(xmlFile)
{
var xmlDoc = loadXML(xmlFile);
if(xmlDoc==null)
{

  alert('您的浏览器不支持xml文件读取,于是本页面禁止您的操作,推荐使用IE5.0以上可以解决此问题!');

window.location.href='/Index.aspx';
}
return xmlDoc;
}

  // 然后开始获取需要的Login/Weapon/W的第一个节点的属性值

var xmlDoc = checkXMLDocObj('/EBS/XML/Login.xml');
var v = xmlDoc.getElementsByTagName('Login/Weapon/W')[0].childNodes.getAttribute('Text')



  而我在我的程序中的写法是这样子的,当然我在程序中的写法是已经应用到实际中的了.一并给出来,以供查看。

+展开
-JavaScript
initializeSelect = function(oid, xPath)
{
var xmlDoc = checkXMLDocObj('/EBS/XML/Login.xml');
var n;
var l;
var e = $(oid);
if(e!=null)
{
n = xmlDoc.getElementsByTagName(xPath)[0].childNodes;
l = n.length;
for(var i=0; i{
var option = document.createElement('option');
option.value = n[i].getAttribute('Value');
option.innerHTML = n[i].getAttribute('Text');
e.appendChild(option);
}
}
}



  上面的访问代码中,我们是通过xmlDoc.getElementsByTagName(xPath)来进行的。

  还可以通过xmlDoc.documentElement.childNodes(1)..childNodes(0).getAttribute('Text')进行访问。


  一些常用方法:其实和XHTML中的js操作dom原属差不多,不过没有document.getElementById,只有node.getElementsByTagName。

  ◆ xmlDoc.documentElement.childNodes(0).nodeName,可以得到这个节点的名称;

  ◆ xmlDoc.documentElement.childNodes(0).nodeValue,可以得到这个节点的值. 这个值是来自于这样子的xml格式:<a>b</b>, 于是可以得到b这个值;

  ◆ xmlDoc.documentElement.childNodes(0).hasChild,可以判断是否有子节点。

  最好是使用getElementsByTagName(xPath)的方法对节点进行访问,因为这样子可以直接通过xPath来定位节点,这样子会有更好的性能。

类别:JavaScript/Ajax 作者:转载 日期:2009-07-02 【评论:8 阅读:1741】 繁體中文
<?xml version="1.0" encoding="gb2312"?>
<employees>
  <employee name="J.Doe"><job>Programmer</job><salary>32768</salary></employee>
  <employee name="A.Baker"><job>Sales</job><salary>70000</salary></employee>
  <employee name="Big Cheese"><job>CEO</job><salary>1000000</salary></employee>
</employees>

test.html,这里使用的是设置div的innerHTML,如果要操作table,你可以查看这篇文章
ie和firefox下操作table对象的异同

+展开-HTML<div id="dvTB"></div><!---这里是接受分析xml文件生成table的父容器--->
<script>
//注意,为了考虑兼容性,请尽量使用 getElementsByTagName来获取节点集合,而不是使用 selectNode('xpath'),selectNode在w3c浏览器不支持,只有ie支持
function ParseXML(dom){
  var dv=document.getElementById('dvTB'),innerHTML='<table border="1"><tr align="center"><td>Name</td><td>Job</td><td>Salary</td></tr>',node
     ,employee=dom.getElementsByTagName("employee");//获取所有employee标签
    
   //遍历employee
   for(var i=0;i<employee.length;i++){
     innerHTML+='<tr><td>'+employee[i].getAttribute('name')+'</td>'//使用getAttribute获取该节点的name属性,和xmhtml差不多的
     node=employee[i].getElementsByTagName("job")[0];//获取当前节点下的所有job节点,因为此节点下只有一个job,所以索引为0
     node=node.firstChild;//注意文本节点也算一个节点,所以还得使用firstChild
     innerHTML+='<td>'+node.nodeValue+'</td>';//获取job节点内的内容
     //同理获取该employee节点下的salary节点,上面为了说明,多分了几个步骤,下面就简化了
     innerHTML+='<td>'+employee[i].getElementsByTagName("salary")[0].firstChild.nodeValue+'</td>';
     innerHTML+='</tr>';//闭合tr
   } 
   innerHTML+='</table>';//闭合table
   //设置div的innerHTML属性
   dv.innerHTML=innerHTML;
}
function loadXML(url)
{
 var xmldoc;
 if(document.implementation&&document.implementation.createDocument){
  xmldoc=document.implementation.createDocument("","",null);
  xmldoc.onload=function(){ParseXML(xmldoc);}
  xmldoc.load(url);
 }
 else if(window.ActiveXObject){
  xmldoc=new ActiveXObject("Microsoft.XMLDOM");
  xmldoc.onreadystatechange=function(){if(xmldoc.readyState==4)ParseXML(xmldoc);}
  xmldoc.load(url);
 }
}
window.onload=function(){loadXML("data.xml");}</script> <br/><br/><br/>本文来自<a href="http://www.code-design.cn">编程设计网</a>,转载请标明出处:<a href="http://www.code-design.cn/blogdetail387.html">http://www.code-design.cn/blogdetail387.html</a>
原创粉丝点击