2012-04-16 3 views
6

Der folgende Code funktioniert in Chrome, aber nicht IE oder FireFox. Kennt jemand den entsprechenden Cross-Browser-Code?

<s:Envelope xmlns:s="http://www.w3.org/2003/05/soap-envelope" xmlns:a="http://www.w3.org/2005/08/addressing"> 
<s:Header> 
    <a:Action s:mustUnderstand="1">http://tempuri.org/SubscriptionService/Update</a:Action> 
    <netdx:Duplex xmlns:netdx="http://schemas.microsoft.com/2008/04/netduplex"> 
     <netdx:Address>http://docs.oasis-open.org/ws-rx/wsmc/200702/anonymous?id=4ed8a7ee-b124-e03e-abf0-a294e99cff73</netdx:Address> 
     <netdx:SessionId>177b4f47-5664-d96c-7ffa-0a8d879b67dd</netdx:SessionId> 
    </netdx:Duplex> 
</s:Header> 
<s:Body> 
    <Update xmlns="http://tempuri.org/"> 
     <lstResponseStruct xmlns:b="http://schemas.datacontract.org/2004/07/FSS.Libs.Core.InterprocessData.RMS" xmlns:i="http://www.w3.org/2001/XMLSchema-instance"> 
      <b:DataA> 
       <b:ValueA>1.339565</b:ValueA> 
       <b:Status>None</b:Status> 
      </b:DataA> 
      <b:DataA> 
       <b:ValueA>120.3717</b:ValueA> 
       <b:Status>None</b:Status> 
      </b:DataA> 
      <b:DataA> 
       <b:ValueA>133.563116</b:ValueA> 
       <b:Status>None</b:Status> 
      </b:DataA> 
      <b:DataA> 
       <b:ValueA>-0.0059159999999999994</b:ValueA> 
       <b:Status>None</b:Status> 
      </b:DataA> 
     </lstResponseStruct> 
    </Update> 
</s:Body> 

Hier ist der JavaScript-Schnipsel ...

<script src="http://code.jquery.com/jquery.min.js" type="text/javascript"></script> 

var nodes; 
if (typeof DOMParser != "undefined") 
    nodes = ((new DOMParser()).parseFromString(request.responseText, "application/xml")).getElementsByTagName("*"); 
else { 
    request.responseXML.loadXML(request.responseText); 
    nodes = request.responseXML.getElementsByTagName("*"); 
} 

for (var i = 0; i < nodes.length; i++) { 
    var element = nodes[i]; 
    ... 
    if ((element.localName == "Body" || element.baseName == "Body") && element.namespaceURI == "http://www.w3.org/2003/05/soap-envelope") { 
     body = element; 
     break; 
} 

$(body).find('DataA').each(function() { 
    ... Do something 
} 

aus irgendeinem Grunde in jedem Browser "Körper" auf jeden Fall enthält den Körper xml, aber der $ (Körper) .find ('DataA') gibt keine Ergebnisse für IE oder FireFox zurück.

Update:

den Namensraum $ Hinzufügen (Körper) .find ('b \\: DataA') funktioniert gut für FireFox und IE, aber bricht Chrome!

+4

Tipp: Verwenden Sie die jQuery-Methode ['$ .parseXML'] (http://api.jquery.com/jQuery.parseXML/). Es gibt ein XMLDocument-Objekt (kein jQuery-Objekt) zurück. Um ein jQuery-Objekt zu erhalten, wickle den Rückgabewert: '$ ($. ParseXML (' Test'));' –

+0

Besser noch, da dies eine Ajax-Anfrage zu sein scheint, verwende jquery 'ajax' und setze den' dataType 'passend (oder lass es jQuery herausfinden) und du wirst nicht einmal' parseXML' direkt aufrufen müssen. –

+0

$ (xData.responseXML) .find ("z \\: row, row"). Je (function() {// Do Stuff}); Scheint für IE, FireFox und Chrome zu funktionieren. – antwarpes

Antwort

12

Es gab ein Problem beim Zugriff auf XML-Knoten ohne den angegebenen Namespace. Aus irgendeinem Grund möchte Chrome den Namespace nicht sehen.

Ich fand, dass der Selektor "b \: DataA" für FireFox und IE funktioniert und der Selektor "DataA" für Chrome funktioniert.

so ...

$(xData.responseXML).find("b\\:DataA, DataA").each(function() { // Do Stuff }); 

scheint für IE, Firefox und Chrome zu arbeiten.

siehe http://www.steveworkman.com/html5-2/javascript/2011/improving-javascript-xml-node-finding-performance-by-2000/ für weitere Informationen und Möglichkeiten zur Verbesserung der XML-Knoten finden Leistung.

+1

Danke, wir haben das gleiche Problem. +1 für die Lösung meines Problems. –

+0

Danke, das hat mein Problem gelöst. Oh, und es funktioniert auch in Safari .. :-) – Drew

0

Es funktioniert gut !!! Versuchen Sie dieses,

Chrome/Firefox:

xml.children[0].childNodes[1].innerHTML; 

IE8 +/Safari:

xml.childNodes[0].childNodes[1].textContent; 

IE8:

xml.documentElement.childNodes[1].text; 

Beispielcode hier,

var xml = $.parseXML(XMLDOC); 

Var xmlNodeValue = ""; 

if(userAgent.match("firefox")){ 

xml.children[0].childNodes[1].innerHTML; 

}else{ // IE8+ 

xmlNodeValue = xml.childNodes[0].childNodes[1].textContent; 

} 
+0

Referenzierung mit hart codierten Positionsindex ist nicht flexibel. – lulalala