最新更新 sitemap 网站制作设计本站搜索
网页设计
国外网站 韩国网站 个人主页 手提袋设计 CSS 网页特效 平面设计 网站设计 Flash CMS技巧 服装网站 php教程 photoshop 画册 服务器选用 数据库 Office
虚拟主机 域名注册 云主机 网页设计 客服QQ:8208442

使Firefox对XML的处理兼容IE的节点处理方法

日期:01-01    来源:中国设计秀    作者:cnwebshow.com

 i4P中国设计秀

使Firefox对XML的处理兼容IE的节点处理方法。具体代码列出如下。i4P中国设计秀

具体代码如下。i4P中国设计秀

i4P中国设计秀
<! DOCTYPE Html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" > i4P中国设计秀
< HTML > i4P中国设计秀
< HEAD > i4P中国设计秀
< TITLE > 使firefox对xml的处理兼容IE的selectSingleNode selectNodes方法 </ TITLE > i4P中国设计秀
< META NAME ="Author" CONTENT ="emu" > i4P中国设计秀
< META NAME ="Keywords" CONTENT ="firefox IE selectSingleNode selectNodes" > i4P中国设计秀
< META NAME ="Description" CONTENT ="使firefox可以支持selectSingleNode selectNodes方法" > i4P中国设计秀
< SCRIPT LANGUAGE ="javascript" > i4P中国设计秀
<!-- i4P中国设计秀
var isIE = !! document.all; i4P中国设计秀
i4P中国设计秀
function parseXML(st){ i4P中国设计秀
if (isIE){ i4P中国设计秀
var result = new ActiveXObject( " microsoft.XMLDOM " ); i4P中国设计秀
result.loadXML(st); i4P中国设计秀
} else { i4P中国设计秀
var parser = new DOMParser(); i4P中国设计秀
var result = parser.parseFromString(st, " text/xml " ); i4P中国设计秀
} i4P中国设计秀
return result; i4P中国设计秀
} i4P中国设计秀
i4P中国设计秀
if ( ! isIE){ i4P中国设计秀
var ex; i4P中国设计秀
XMLDocument.prototype.__proto__.__defineGetter__( " xml " , function (){ i4P中国设计秀
try { i4P中国设计秀
return new XMLSerializer().serializeToString( this ); i4P中国设计秀
} catch (ex){ i4P中国设计秀
var d = document.createElement( " div " ); i4P中国设计秀
d.appendChild( this .cloneNode( true )); i4P中国设计秀
return d.innerHTML; i4P中国设计秀
} i4P中国设计秀
}); i4P中国设计秀
Element.prototype.__proto__.__defineGetter__( " xml " , function (){ i4P中国设计秀
try { i4P中国设计秀
return new XMLSerializer().serializeToString( this ); i4P中国设计秀
} catch (ex){ i4P中国设计秀
var d = document.createElement( " div " ); i4P中国设计秀
d.appendChild( this .cloneNode( true )); i4P中国设计秀
return d.innerHTML; i4P中国设计秀
} i4P中国设计秀
}); i4P中国设计秀
XMLDocument.prototype.__proto__.__defineGetter__( " text " , function (){ i4P中国设计秀
return this .firstChild.textContent i4P中国设计秀
}); i4P中国设计秀
Element.prototype.__proto__.__defineGetter__( " text " , function (){ i4P中国设计秀
return this .textContent i4P中国设计秀
}); i4P中国设计秀
i4P中国设计秀
XMLDocument.prototype.selectSingleNode = Element.prototype.selectSingleNode = function (XPath){ i4P中国设计秀
var x = this .selectNodes(xpath) i4P中国设计秀
if ( ! x x.length < 1 ) return null ; i4P中国设计秀
return x[ 0 ]; i4P中国设计秀
} i4P中国设计秀
XMLDocument.prototype.selectNodes = Element.prototype.selectNodes = function (xpath){ i4P中国设计秀
var xpe = new XPathEvaluator(); i4P中国设计秀
var nsResolver = xpe.createNSResolver( this .ownerDocument == null ? i4P中国设计秀
this .documentElement : this .ownerDocument.documentElement); i4P中国设计秀
var result = xpe.evaluate(xpath, this , nsResolver, 0 , null ); i4P中国设计秀
var found = []; i4P中国设计秀
var res; i4P中国设计秀
while (res = result.iterateNext()) i4P中国设计秀
found.push(res); i4P中国设计秀
return found; i4P中国设计秀
} i4P中国设计秀
} i4P中国设计秀
var x = parseXML( " <people> <person first-name= " eric " middle-initial= " H " last-name= " jung " > <address street= " 321 south st " city= " denver " state= " co " country= " usa " /> <address street= " 123 main st " city= " arlington " state= " ma " country= " usa " /> </person> <person first-name= " jed " last-name= " brown " > <address street= " 321 north st " city= " atlanta " state= " ga " country= " usa " /> <address street= " 123 west st " city= " seattle " state= " wa " country= " usa " /> <address street= " 321 south avenue " city= " denver " state= " co " country= " usa " /> </person></people> " ); i4P中国设计秀
i4P中国设计秀
alert( " 搜索所有人的姓氏(last-name) " ) i4P中国设计秀
var results = x.selectNodes( " " ); i4P中国设计秀
for ( var i = 0 ; i < results.length;i ++ ) i4P中国设计秀
alert( " Person # " + i + " has the last name " + results[i].nodeValue); i4P中国设计秀
alert( " 搜索第二个人 " ); i4P中国设计秀
// IE是以0为下标基数的,而不是1 i4P中国设计秀
if ( ! document.all) i4P中国设计秀
results = x.selectSingleNode( " /people/person[2] " ); i4P中国设计秀
else i4P中国设计秀
results = x.selectSingleNode( " /people/person[1] " ); i4P中国设计秀
alert(results.xml) i4P中国设计秀
i4P中国设计秀
alert( " 获得住址在donver街上的人 " ); i4P中国设计秀
results = x.selectNodes( " //person[address/@city='denver'] " ); i4P中国设计秀
for ( var i = 0 ; i < results.length;i ++ )alert(results[i].xml) i4P中国设计秀
i4P中国设计秀
if ( ! document.all){ i4P中国设计秀
// 获得所有街名中带south的地址 i4P中国设计秀
results = x.selectNodes( " //address[contains(@street, 'south')] " ); i4P中国设计秀
alert(results[ 0 ].xml); i4P中国设计秀
} else { i4P中国设计秀
alert( " IE不支持 //address[contains(@street, 'south')] 这种查询方式 " ) i4P中国设计秀
} i4P中国设计秀
// --> i4P中国设计秀
</ SCRIPT > i4P中国设计秀
</ HEAD > i4P中国设计秀
< BODY > i4P中国设计秀
</ BODY > i4P中国设计秀
</ HTML > i4P中国设计秀
 
i4P中国设计秀

例子引自 。从例子可以看到,IE对xpath的支持还是有限度的。i4P中国设计秀