JS和XML问题 50

如何用JS获取XML文档中指定节点的所有下一级子节点。大哥帮忙列举下不常用的方法。我需要的就是不常用的。... 如何用JS获取XML文档中指定节点的所有下一级子节点。
大哥帮忙列举下不常用的方法。
我需要的就是不常用的。
展开
 我来答
ys5955092
2010-10-27 · TA获得超过671个赞
知道小有建树答主
回答量:551
采纳率:100%
帮助的人:573万
展开全部
XML文档对象模型
1)DOMDocument对象:该对象描述全部的文档映射表,文档映射表包含了XML文档里的所有信息。
常用方法
常用属性

2)IXMLDOMNode对象:该对象描述XML文档里的节点。这个节点可以是元素、属性、处理指令、文本或者其他存储在XML文档里的信息。
常用方法
常用属性

3)IXMLDOMNodeList对象:该对象描述IXMLDOMNode对象的集合,并可使用该对象遍历这个集合。IXMLDOMNodeList对象里的节点集合可以用数值该问。
常用方法
常用属性

4)IXMLDOMParseError对象:该对象用来验证XML文档对于Schema或DTD的正确性,并且取得在验证过程中产生的错误信息。
常用方法
常用属性

* DOMDocument对象常用方法:
a)createElement(elementName) ---- 该方法以元素名为参数创建一个用此参数命名的元素节点。(不能创建名称空间受限制的元素。如果要创建名称空间受限制的元素,必须使用createNode()方法)
例: doc.createElement("PRODUCT"),有些用到:doc-> creatElement('item')

b)createAttribute(attributeName) ---- 该方法以属性名为参数创建一个用此参数命名的属性节点。
例: doc.createAttribute("PRODID")
xml中表现形式:<item upload_name="上3"><download_name>下载通道名称</download_name></item>

c)createComment(text) ---- 该方法以字符串为参数创建一个包含此字符串的注释节点。
例: doc.createComment("This is an XML document")
<item><!--upload_name--><download_name>下载通道名称</download_name></item>
d)createTextNode(text) ---- 该方法以字符串为参数创建一个包含指定字符串的正文节点。
例: doc.createTextNode("Sony Workman")

e)createNode(type,name,namespace-URI) ---- 该方法创建元素节点。三个参数,"类型"参数是variant型,既可以是字符串也可以是整型。第二个参数是字符串,它代表将要创建的节点的名字。第三个参数是代表namespace-URI的字符串。如果namespace-URI为空字符串,则新创建的节点就没有名称空间URI
例: doc.createNode("element","PRODUCT","")
doc.createNode("element","prod: PRODUCT","blog.csdn.net/fcrpg2005")
doc.createNode(1,"PRODUCT","")

f)getElementsByTagName(elementName) ---- 该方法以字符串为参数。这个字符串是要搜索的元素。返回IXMLDOMNodeList对象,包含指定元素名称的节点的集合。可以用这些节点信来浏览操纵存储在指定元素中的值。
例: doc.getEelmentsByTagName("PRICE")

g)load(XMLdocument) ---- 该方法以字符串为参数。这个字符串是XML文档的地址(HTTP地址或本地地址)
例: doc.load("http://blog.csdn.net/fcrpg2005/product.xml")
doc.load("D:\product.xml")

h)loadXML(string) ---- 该方法把成形的XML代码或整个XML文档载入DOMDocument对象中。
例: doc.loadXML("<?xml version=1.0><PRODUCTS><PRODUCT><name>Barbie Doll</name></PRODUCT></PRODUCTS>")

i)transformNode(stylesheet object) ---- 该方法以风格表对象为参数。通过把相应的风格表加到XML文档上来处理节点,然后返回转换结果。
例: doc.transformNode("product.xsl")

j)appendChild(child node) ---- 该方法以对象为参数。把这个对象作为最后的子节点加在XML文档上。createNode() 或者 createElement()方法可以创建节点或元素。但是它们不会把新建的节点加到文档树形结构上。而是需要用appendChild()方法,insertBefore()方法,或者replaceChild()方法把新建的节点加上去。
例: doc.appendChild(root) ---- PS: root是一个用createNode()或createElement()方法创建的节点

k)save(destination) ---- 该方法以对象为参数。这个对象可以是一个DOMDocument对象也可以是一个文件名。save()方法把DOMDocument对象保存在指定的目的地。
例: doc.save("http://blog.csdn.net/fcrpg2005/product.xml")

* DOMDocument对象常用属性:
a)async ---- 该属性用来指定是否允许异步加载。属性async取布尔值。
例: doc.async = false --同步

b)childNodes ---- 该属性返回属于一个父节点的子节点集合(即返回当前元素所有子元素的数组对象)。该属性的值是对象IXMLDOMNodeList的类型。
例: var firstelem = doc.childNodes.item(0)

c)documentElement ---- 该属性包含用对象DOMDocument表示的XML文档的根元素。
例: var root = doc.documentElement

d)firstChild ---- 该属性返回父元素的第一个子节点。该元素是只读的。
例: var firstelem = doc.firstChild

e)lastChild ---- 该属性返回父元素的最后一个子节点。
例: var lastelem = doc.lastChild

f)parseError ---- 该属性返回一个包含大部分最近产生的错误信息的对象。
例: var error = doc.parseError

g)readyState ---- 该属性返回XML文档的状态。它显示这个文档是否已完全载入。4个状态:0-未初始化、1-正在加载、2-已加载、3-交互中、4-已完成
例: var stateInfo = doc.readState
if(stateInfo == 4) { // Document loading
// Coding
}

h)xml ---- 该属性返回一个节点以有其子节点的XML表示。
例: document.write(doc.xml)

i)validateOnParse ---- 该属性指定解析器是否在解析XML文档时验证其合法性。
例: doc.validateOnParse = true

** IXMLDOMNode对象常用方法:
a)appendChild(newChild) ---- 该方法把节点newChild加到该方法使用的节点的子节点的末尾。

b)insertBefore(newNode, refNode) ---- 该方法把一个新节点newNode插到一个已存在节点refNode之前。

c)removeChild(nodeName) ---- 该方法删除指定的节点。

d)replaceChild(newNode, oldNode) ---- 该方法用新节点newNode替换旧节点oldNode。

e)hasChildNodes() ---- 如果IXMLDOMNode对象有子节点,该方法返回值为真(true)。

f)cloneNode(Boolean) ---- 如果参数Boolean为真,该方法返回IXMLDOMNode对象一个完全克隆。该克隆节点包含和原节点一样的子节点。

** IXMLDOMNode对象常用属性:
a)nodeName ---- 返回节点名称。

b)nodeType ---- 返回节点类型。

c)nodeValue ---- 返回节点包含的文本。

d)childNodes ---- 返回用IXMLDOMNode对象表示的节点的子节点集。

e)firstChild ---- 返回该节点的第一个子节点。

f)lastChild ---- 返回该节点的最后一个子节点。

g)text ---- 返回IXMLDOMNode在IXMLDOMNode对象中的文本。

h)xml ---- 返回IXMLDOMNode对象的XML代码

*** IXMLDOMNodeList对象常用方法:
a)item(number) ---- 该方法返回指定数值对应位置的节点。

b)nextNode() ---- 该方法返回节点集的下一个节点。

*** IXMLDOMNodeList对象常用属性:
length ---- 获得节点集中节点的个数。

**** IXMLDOMParseError对象常用属性:
a)errorCode ---- 该属性包含类型为长整型的错误代码。如果XML文档没有错误,该属性返回0。

b)reason ---- 该属性包含解释错误原因的字符串。

c)line ---- 该属性存储代表错误行数的长整型。

d)linePos ---- 该属性存储代表错误行位置的长整型。

e)srcText ---- 该属性包含引起错误的那一行字符串。

与使用 removeChild() 不同的是,应用程序简单地使用了replaceChild()。注意在此例中,该方法还会返回旧的节点,以便能根据需要将它移往别处,或许是移到一个新 Document,该 Document 列出所有订单不足的商品。注意由于没有内容被添加到该元素,因此它是一个空元素。空元素没有内容,并且可以用一种特殊的简写来表示:<backordered /> 斜线(/)消除了对结束标签(</backordered>)的需要。...
if (thisOrderItem.getAttributeNode("instock")
.getNodeValue().equals("N")) {

Element backElement = doc.createElement("backordered");

Node deadNode = thisOrderItem.getParentNode()
.replaceChild(backElement, thisOrderItem);

}
创建和设置属性
没有标志表明一个 backordered 元素是什么商品,那该怎么正确处理它呢?纠正信息缺乏的方法之一是向元素添加属性。应用程序首先创建一个 itemid 属性。接下来,它根据原先的 item 元素确定 itemid 的值,然后再自己设置该属性的值。最后,它把该元素添加到文档,就像以前一样。...
if (thisOrderItem.getAttributeNode("instock")
.getNodeValue().equals("N")) {

Element backElement = doc.createElement("backordered");

backElement.setAttributeNode(doc.createAttribute("itemid"));

String itemIdString =
thisOrderItem.getAttributeNode("itemid").getNodeValue();
backElement.setAttribute("itemid", itemIdString);

Node deadNode = thisOrderItem.getParentNode().replaceChild(backElement,
thisOrderItem);

} else {
...
如果具有该名称的节点不存在, setAttribute() 就会创建一个属性节点。

删除属性

应用程序还可以删除属性。例如,在输出中显示客户信用限额信息也许是不可取的,因此应用程序可以临时地将该属性从文档中删除。删除信息是相当简单的,只需使用 removeAttribute() 来删除数据。...
Element thisOrder = (Element)orders.item(orderNum);

Element customer =
(Element)thisOrder.getElementsByTagName("customerid")
.item(0);
customer.removeAttribute("limit");

NodeList orderItems = thisOrder.getElementsByTagName("item");
...
killzem
2010-10-26 · TA获得超过247个赞
知道小有建树答主
回答量:254
采纳率:0%
帮助的人:167万
展开全部
首先需要加载这个xml文件,JavaScript中加载xml文件,是通过XMLDOM来进行的:
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;

}

一些常用方法:

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

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

xmlDoc.documentElement.childNodes(0).hasChild,可以判断是否有子节点。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
panelwork
2010-10-27 · TA获得超过615个赞
知道小有建树答主
回答量:562
采纳率:0%
帮助的人:573万
展开全部
不常用的不知道,xml解析器基本都是那些操作

我常用的就是xpath

var node = xmlNode.SelectSingleNode('//nodename[属性名=属性值]'); //如果有特殊属性可以用

找到该节点,然后用node.childNodes获取子节点
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式