js 解析xml

 最近一个项目中要用到树形列表,本来是用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.οnlοad=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.οnlοad=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>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值