脚本代码:实例解析Js+XML的操作方法

本文介绍如何使用JavaScript加载和解析XML文件,并提供了通过XPath查询特定节点属性的示例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我的xml文件Login.xml如下.
<?xmlversion="1.0"encoding="utf-8"?>
<Login>
<Character>
<CText="热血"Value="0"></C>
<CText="弱气"Value="1"></C>
<CText="激情"Value="2"></C>
<CText="冷静"Value="3"></C>
<CText="冷酷"Value="4"></C>
</Character>
<Weapon>
<WText="光束剑"Value="0"></W>
<WText="光束配刀"Value="1"></W>
</Weapon>
<EconomyProperty>
<PText="平均型"Value="0"></P>
<PText="重视攻击"Value="1"></P>
<PText="重视敏捷"Value="2"></P>
<PText="重视防御"Value="3"></P>
<PText="重视命中"Value="4"></P>
</EconomyProperty>
</Login>

现在我需要对这个xml文件的内容进行操作.
首先,我们需要加载这个xml文件,js中加载xml文件,是通过XMLDOM来进行的.
//加载xml文档
loadXML=function(xmlFile)
{
varxmlDoc;
if(window.ActiveXObject)
{
xmlDoc
=newActiveXObject('Microsoft.XMLDOM');
xmlDoc.async
=false;
xmlDoc.load(xmlFile);
}
elseif(document.implementation&&document.implementation.createDocument)
{
xmlDoc
=document.implementation.createDocument('','',null);
xmlDoc.load(xmlFile);
}
else
{
returnnull;
}

returnxmlDoc;
}

xml文件对象出来了, 接下去我就要对这个文档进行操作了.
比如说,我们现在需要得到节点Login/Weapon/W的第一个节点的属性,那么我们可以如下进行.

//首先对xml对象进行判断
checkXMLDocObj=function(xmlFile)
{
varxmlDoc=loadXML(xmlFile);
if(xmlDoc==null)
{
alert('您的浏览器不支持xml文件读取,于是本页面禁止您的操作,推荐使用IE5.0以上可以解决此问题
!');
window.location.href
='/Index.aspx';
}

returnxmlDoc;
}

//然后开始获取需要的Login/Weapon/W的第一个节点的属性值
varxmlDoc=checkXMLDocObj('/EBS/XML/Login.xml');
varv=xmlDoc.getElementsByTagName('Login/Weapon/W')[0].childNodes.getAttribute('Text')

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

initializeSelect=function(oid,xPath)
{
varxmlDoc=checkXMLDocObj('/EBS/XML/Login.xml');
varn;
varl;
vare=$(oid);
if(e!=null)
{
n
=xmlDoc.getElementsByTagName(xPath)[0].childNodes;
l
=n.length;
for(vari=0;i<l;i++)
{
varoption=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')进行访问.
一些常用方法:
xmlDoc.documentElement.childNodes(0).nodeName,可以得到这个节点的名称.
xmlDoc.documentElement.childNodes(0).nodeValue,可以得到这个节点的值. 这个值是来自于这样子的xml格式:<a>b</b>, 于是可以得到b这个值.
xmlDoc.documentElement.childNodes(0).hasChild,可以判断是否有子节点

根据我的经验,最好是使用getElementsByTagName(xPath)的方法对节点进行访问,因为这样子可以直接通过xPath来定位节点,这样子会有更好的性能.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值