【www.bbyears.com--浏览器】
遍历节点树
您经常需要循环 XML 文档,比如:当你需要提取每个元素的值时。
这个过程叫作“遍历节点树”
读取服务器端xml(注意不同浏览器版本的区别),使用XML可以增强系统的扩展性,只用修改XML就可以实现增加减少功能的目的。
if (window.XMLHttpRequest){
xhttp=new XMLHttpRequest();
}else{
xhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",dname,false);
xhttp.send("");
return xhttp.responseXML;
}
2:遍历XML节点
getElementsByTagName() 方法可以在取得一个节点后继续调用获得子节点,并且返回的是一个数组(只有一个节点时也要加上[0])
.childNodes[0].nodeValue) 取得一个节点的值的办法,节点的值也是节点(文本节点)
var xml=loadXMLDoc1("book.xml");
var bookss=xml.getElementsByTagName("book");
for(var i=0;i
document.write("");
document.write(bookss[i].getElementsByTagName("author")[0].childNodes[0].nodeValue);
document.write("");
document.write(bookss[i].getElementsByTagName("year")[0].childNodes[0].nodeValue);
document.write("");
document.write(bookss[i].getElementsByTagName("price")[0].childNodes[0].nodeValue);
document.write("");
}
}
3:CDATA节点值读取
如果一个XML节点中是CDATA,读取时不同浏览器的方法不同,在IE下nodeValue可以正常获取到值,在FF和chrome下通过wholeText读取。
如果一个节点浏览器不支持,可以使用if进行判断。
var xml=loadXMLDoc1("ceshi.xml");
var HightChartsOpinions=xml.getElementsByTagName("HightChartsOpinions");
for(var i=0;i
var text=wholeTextData?wholeTextData:HightChartsOpinions[i].childNodes[0].nodeValue
document.write(text);
document.write("");
}
return false;
}
4: 通过XPATH进行XML的遍历
XPATH可以非常强大的进行XML节点的过滤,以下的链接中包含了常用的xpath用法。
http://www.w3school.com.cn/xpath/xpath_examples.asp
xpath读取xml 不同浏览器也有不同的方法实现,这里使用回调函数处理返回节点。
function xpath() {
var xmlFilePath="book.xml";
var xpath="/bookstore/book[price>45]";
var callback=function(element) {
document.write(element.getElementsByTagName("title")[0].childNodes[0].nodeValue);
document.write("");
document.write(element.getElementsByTagName("author")[0].childNodes[0].nodeValue);
document.write("");
document.write(element.getElementsByTagName("year")[0].childNodes[0].nodeValue);
document.write("");
document.write(element.getElementsByTagName("price")[0].childNodes[0].nodeValue);
document.write("");
};
handlerXML(xmlFilePath,xpath,callback);
}
function handlerXML(xmlFilePath,xpath,callback) {
var xml=loadXMLDoc1(xmlFilePath);
var action;
if (window.ActiveXObject)
{
var nodes=xml.selectNodes(xpath);
for (i=0;i
}
}else if (document.implementation && document.implementation.createDocument){
var nodes=xml.evaluate(xpath, xml, null, XPathResult.ANY_TYPE, null);
var result=nodes.iterateNext();
while (result){
callback(result);
result=nodes.iterateNext();
}
}
}
JavaScript 解析和生成 XML
用 JS 解析和生成 XML 一般都是使用 DOMDocument 这个对象, 下面简单的列出其属性和方法:
属性:
Attributes 存储节点的属性列表 (只读)
childNodes 存储节点的子节点列表 (只读)
dataType 返回此节点的数据类型
Definition 以DTD或XML模式给出的节点的定义 (只读)
Doctype 指定文档类型节点 (只读)
documentElement 返回文档的根元素 (可读写)
firstChild 返回当前节点的第一个子节点 (只读)
Implementation 返回XMLDOMImplementation对象
lastChild 返回当前节点最后一个子节点 (只读)
nextSibling 返回当前节点的下一个兄弟节点(只读)
nodeName 返回节点的名字 (只读)
nodeType 返回节点的类型 (只读)
nodeTypedValue 存储节点值 (可读写)
nodeValue 返回节点的文本 (可读写)
ownerDocument 返回包含此节点的根文档 (只读)
parentNode 返回父节点 (只读)
Parsed 返回此节点及其子节点是否已经被解析 (只读)
Prefix 返回名称空间前缀 (只读)
preserveWhiteSpace 指定是否保留空白 (可读写)
previousSibling 返回此节点的前一个兄弟节点 (只读)
Text 返回此节点及其后代的文本内容 (可读写)
url 返回最近载入的XML文档的URL (只读)
Xml 返回节点及其后代的XML表示 (只读)
方法:
appendChild 为当前节点添加一个新的子节点,放在最后的子节点后
cloneNode 返回当前节点的拷贝
createAttribute 创建新的属性
createCDATASection 创建包括给定数据的CDATA段
createComment 创建一个注释节点
createDocumentFragment 创建DocumentFragment对象
createElement 创建一个元素节点
createEntityReference 创建EntityReference对象
createNode 创建给定类型,名字和命名空间的节点
createPorcessingInstruction 创建操作指令节点
createTextNode 创建包括给定数据的文本节点
getElementsByTagName 返回指定名字的元素集合
hasChildNodes 返回当前节点是否有子节点
insertBefore 在指定节点前插入子节点
Load 导入指定位置的XML文档
loadXML 导入指定字符串的XML文档
removeChild 从子结点列表中删除指定的子节点
replaceChild 从子节点列表中替换指定的子节点
Save 把XML文件存到指定节点
selectNodes 对节点进行指定的匹配,并返回匹配节点列表
selectSingleNode 对节点进行指定的匹配,并返回第一个匹配节点
transformNode 使用指定的样式表对节点及其后代进行转换
transformNodeToObject 使用指定的样式表将节点及其后代转换为对象