Hopes

Start Here..

 

兼容IE、FireFox、Chrome等浏览器的xml处理函数js代码

在编写处理xml的网页时,经常为浏览器兼容性头疼。于是我将常用的xml操作封装为函数。经过一段时间的改进,现在已经很稳定了,用起来很舒服。
函数有——
xml_loadFile:xml同步/异步加载。
xml_transformNode:xsl转换。
xml_text:节点的文本。
selectSingleNode:根据XPath选择单个节点。
selectNodes:根据XPath选择多个节点。
全部代码(zyllibjs_xml.js)——
zyllibjs_xml 
XML处理 
@author zyl910 
注意—— 
1. Chrome 由于其安全机制限制, 不能读取本地文件。 
Reference 
~~~~~~~~~ 
http:
//www.jinlie.net/?p=302 
Chrome浏览器加载XML文档 
Update 
~~~~~~ 
[
2011-11-02
定义。 
[
2011-11-09
xml_loadFile: 为回调函数加上isError参数。 
[
2011-11-21
selectSingleNode 
selectNodes 
*/ 
// 加载XML文件并返回XML文档节点 
// return: 成功时返回一个对象(同步模式下返回xml文档对象,异步模式下返回操作对象),失败时返回空。 
// xmlUrl: xml文件的url。 
// funcAsync: 回调函数. function onload(xmlDoc, isError){  } 
function xml_loadFile(xmlUrl, funcAsync) 

var xmlDoc 
= null
var isChrome 
= false
var asyncIs 
= (null!=funcAsync); // 是否是异步加载。当funcAsync不为空时,使用异步加载,否则是同步加载。 
// 检查参数 
if (""==xmlUrl) return null
if (asyncIs) 

if ("function"!=typeof(funcAsync)) return null

// 创建XML对象 
try 

xmlDoc 
= new ActiveXObject("Microsoft.XMLDOM"); // Support IE 

catch(ex) 


if (null==xmlDoc) 

try 

// Support Firefox, Mozilla, Opera, etc 
xmlDoc = document.implementation.createDocument(""""null); // 创建一个空的 XML 文档对象。 

catch(ex) 



if (null==xmlDoc) return null
// 加载XML文档 
xmlDoc.async = asyncIs; 
if (asyncIs) 

if(window.ActiveXObject) 

xmlDoc.onreadystatechange 
= function(){ 
if(xmlDoc.readyState == 4

var isError 
= false
if (null!=xmlDoc.parseError) 

isError 
= (0!=xmlDoc.parseError.errorCode); // 0成功, 非0失败。 

funcAsync(xmlDoc, isError); 



else 

xmlDoc.onload 
= function(){ 
funcAsync(xmlDoc, 
false); 



try 

xmlDoc.load(xmlUrl); 

catch(ex) 

// alert(ex.message) // 如果浏览器是Chrome,则会catch这个异常:Object # (a Document) has no method "load" 
isChrome = true
xmlDoc 
= null

if (isChrome) 

var xhr 
= new XMLHttpRequest(); 
if (asyncIs) // 异步 

xhr.onreadystatechange 
= function(){ 
if(xhr.readyState == 4

funcAsync(xhr.responseXML, xhr.status 
!= 200); 


xhr.open(
"GET", xmlUrl, true); 
try // 异步模式下,由回调函数处理错误。 

xhr.send(
null); 

catch(ex) 

funcAsync(
nulltrue); 
return null

return xhr; // 注意:返回的是XMLHttpRequest。建议异步模式下仅用null测试返回值。 

else // 同步 

xhr.open(
"GET", xmlUrl, false); 
xhr.send(
null); // 同步模式下,由调用者处理异常 
xmlDoc = xhr.responseXML; 


return xmlDoc; 

// 使用XSLT把XML文档转换为一个字符串。 
function xml_transformNode(xmlDoc, xslDoc) 

if (null==xmlDoc) return ""
if (null==xslDoc) return ""
if (window.ActiveXObject) // IE 

return xmlDoc.transformNode(xslDoc); 

else // FireFox, Chrome 

//定义XSLTProcesor对象 
var xsltProcessor=new XSLTProcessor(); 
xsltProcessor.importStylesheet(xslDoc); 
// transformToDocument方式 
var result=xsltProcessor.transformToDocument(xmlDoc); 
var xmls
=new XMLSerializer(); 
var rt 
= xmls.serializeToString(result); 
return rt; 


// 得到节点的文本 
function xml_text(xmlNode) 

if (null==xmlNode) return ""
var rt; 
if (window.ActiveXObject) // IE 

rt 
= xmlNode.text; 

else 

// FireFox, Chrome,  
rt = xmlNode.textContent; 

if (null==rt) rt=xmlNode.nodeValue; // XML DOM 
return rt; 

// 添加方法。为了兼容FireFox、Chrome。 
if (!window.ActiveXObject) 

XMLDocument.prototype.selectSingleNode 
= Element.prototype.selectSingleNode = function (xpath) 

var x 
= this.selectNodes(xpath) 
if ( ! x || x.length < 1 ) return null ; 
return x[ 0 ]; 

XMLDocument.prototype.selectNodes 
= Element.prototype.selectNodes = function (xpath) 

var xpe 
= new XPathEvaluator(); 
var nsResolver 
= xpe.createNSResolver( this.ownerDocument == null?this.documentElement : this.ownerDocument.documentElement); 
var result 
= xpe.evaluate(xpath, this , nsResolver, 0 , null ); 
var found 
= []; 
var res; 
while (res = result.iterateNext()) 
found.push(res); 
return found; 

}




Chrome浏览器加载XML文档 
Chrome浏览器不支持load方法加载XML文档。网上找了下,需要如下解决: 
复制代码
 代码如下:

function loadXMLDoc(xml_name) 

var xmlDoc; 
try 

xmlDoc 
= new ActiveXObject("Microsoft.XMLDOM"); // Support IE 
} 
catch(e) 

try 

// Support Firefox, Mozilla, Opera, etc 
xmlDoc = document.implementation.createDocument(""""null) ;// 创建一个空的 XML 文档对象。 

catch(e) 

alert(e.message); 


// 加载XML文档 
try 

xmlDoc.async 
= false// 关闭异步加载 
xmlDoc.load(xml_name); 

catch(e) 

// alert(e.message) 如果浏览器是Chrome,则会catch这个异常:Object # (a Document) has no method "load",所以,以下实现支持chrome加载XML文档(只是粗略的写下) 
var xhr = new XMLHttpRequest(); 
xhr.open(
"GET", xml_name, false); 
xhr.send(
null); 
xmlDoc 
= xhr.responseXML.documentElement; 

return xmlDoc; 


BTW,各浏览器加载XML字符串也不同。 
IE使用 loadXML() 方法来解析 XML 字符串: 
复制代码
 代码如下:
xmlDoc.loadXML(xml_str);

posted on 2012-11-16 21:07 ** 阅读(525) 评论(0)  编辑  收藏


只有注册用户登录后才能发表评论。


网站导航:
 

导航

统计

公告

你好!

常用链接

留言簿(2)

随笔档案

文章分类

文章档案

新闻档案

相册

收藏夹

C#学习

友情链接

搜索

最新评论

阅读排行榜

评论排行榜