使Firefox对XML的处理兼容IE的节点处理方法。具体代码列出如下。

具体代码如下。

  1. <! DOCTYPE Html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" > 
  2. < HTML > 
  3. < HEAD > 
  4. < TITLE > 使firefox对xml的处理兼容IE的selectSingleNode selectNodes方法 </ TITLE > 
  5. < META NAME ="Author" CONTENT ="emu" > 
  6. < META NAME ="KeyWords" CONTENT ="firefox IE selectSingleNode selectNodes" > 
  7. < META NAME ="Description" CONTENT ="使firefox可以支持selectSingleNode selectNodes方法" > 
  8. < SCRIPT LANGUAGE ="javascript" > 
  9. <!-- 
  10. var isIE = !! document.all
  11.  
  12. function parseXML(st){ 
  13. if (isIE){ 
  14. var result = new ActiveXObject( " microsoft.XMLDOM " ); 
  15. result.loadXML(st); 
  16. } else { 
  17. var parser = new DOMParser(); 
  18. var result = parser.parseFromString(st, " text/xml " ); 
  19. return result; 
  20.  
  21. if ( ! isIE){ 
  22. var ex; 
  23. XMLDocument.prototype.__proto__.__defineGetter__( " xml " , function (){ 
  24. try { 
  25. return new XMLSerializer().serializeToString( this ); 
  26. } catch (ex){ 
  27. var d = document.createElement( " div " ); 
  28. d.appendChild( this .cloneNode( true )); 
  29. return d.innerHTML; 
  30. }); 
  31. Element.prototype.__proto__.__defineGetter__( " xml " , function (){ 
  32. try { 
  33. return new XMLSerializer().serializeToString( this ); 
  34. } catch (ex){ 
  35. var d = document.createElement( " div " ); 
  36. d.appendChild( this .cloneNode( true )); 
  37. return d.innerHTML; 
  38. }); 
  39. XMLDocument.prototype.__proto__.__defineGetter__( " text " , function (){ 
  40. return this .firstChild.textContent 
  41. }); 
  42. Element.prototype.__proto__.__defineGetter__( " text " , function (){ 
  43. return this .textContent 
  44. }); 
  45.  
  46. XMLDocument.prototype.selectSingleNode = Element.prototype.selectSingleNode = function (XPath){ 
  47. var x = this .selectNodes(xpath) 
  48. if ( ! x x.length < 1 ) return null ; 
  49. return x[ 0 ]; 
  50. XMLDocument.prototype.selectNodes = Element.prototype.selectNodes = function (xpath){ 
  51. var xpe = new XPathEvaluator(); 
  52. var nsResolver = xpe.createNSResolver( this .ownerDocument == null ? 
  53. this .documentElement : this .ownerDocument.documentElement); 
  54. var result = xpe.evaluate(xpath, this , nsResolver, 0 , null ); 
  55. var found = []; 
  56. var res; 
  57. while (res = result.iterateNext()) 
  58. found.push(res); 
  59. return found; 
  60. 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> " ); 
  61.  
  62. alert( " 搜索所有人的姓氏(last-name) " ) 
  63. var results = x.selectNodes( " " ); 
  64. for ( var i = 0 ; i < results.length;i ++ ) 
  65. alert( " Person # " + i + " has the last name " + results[i].nodeValue); 
  66. alert( " 搜索第二个人 " ); 
  67. // IE是以0为下标基数的,而不是1 
  68. if ( ! document.all
  69. results = x.selectSingleNode( " /people/person[2] " ); 
  70. else 
  71. results = x.selectSingleNode( " /people/person[1] " ); 
  72. alert(results.xml) 
  73.  
  74. alert( " 获得住址在donver街上的人 " ); 
  75. results = x.selectNodes( " //person[address/@city='denver'] " ); 
  76. for ( var i = 0 ; i < results.length;i ++ )alert(results[i].xml) 
  77.  
  78. if ( ! document.all){ 
  79. // 获得所有街名中带south的地址 
  80. results = x.selectNodes( " //address[contains(@street, 'south')] " ); 
  81. alert(results[ 0 ].xml); 
  82. } else { 
  83. alert( " IE不支持 //address[contains(@street, 'south')] 这种查询方式 " ) 
  84. // --> 
  85. </ SCRIPT > 
  86. </ HEAD > 
  87. < BODY > 
  88. </ BODY > 
  89. </ HTML > 


例子引自 。从例子可以看到,IE对xpath的支持还是有限度的。