steckl: Dynamische Wertzuweisung

Beitrag lesen

Hi,

function ausgeben() {
   if (http.readyState == 1) {
      document.write("wird noch ermittelt...");

Ist an dieser Stelle das Dokument schon fertig geladen? Dann überschreibst du hier nämlich die komplette Seite.

} else if (http.readyState == 4) {
var daten = http.responseText;
       daten =  eval("("+daten+")");
document.getElementsByName("Verfuegbarkeit")[i].firstChild.nodeValue=;
for (var i = 0; i < daten.length; i++) {
         var lin = daten[i];
         var test = lin.P;
  alert(lin.P);
   document.getElementById(test).firstChild.nodeValue=lin.A;
      }
}
<table>
  <tr>
     <td>
       <div id="#FoundItem:ItemID#">&nbsp;</div>

Diese id finde ich etwas komisch, aber keine Ahnung, ob sowas erlaubt ist.

</td>
  </tr>
</table>

Warum eine Tabelle mit einer Zeile und einer Spalte?

Diese Funktion rufe ich im Zusammenhang mit einer AJAX-Anwendung auf.  So läuft die Funktion in IE einwandfrei, nicht aber in Firefox. In Firefox bekomme ich die Meldung: 'document.getElementById(test) has no properties'.

Das liegt wohl daran, dass du das Element, das du ansprechen willst vorher mit document.write() überschrieben hast.

Wenn ich die Zeile alert(test); auskommentiere, dann läuft das ganz auch nicht mehr unter IE, dort bekomme ich dann die Meldung: 'Object erforderlich'.

Diese Zeile kommt in deinem Beispielcode garnicht vor.

Kann mir vielleich einer von Euch sagen, was da falsch ist?

Verwende anstatt document.write() etwas anderes.

mfG,
steckl