Steffen: AJAX: Ganzes Formular senden

Hallo,
ich beschäftige mich gerade einwenig mit AJAX:

Bisher sende ich so an die Zieldatei:

  
http.open('POST', 'calc.php', true);  
http.setRequestHeader('Content-Type',  
    'application/x-www-form-urlencoded');  
http.send("1=" + document.getElementById('1').value);  
//Line 26 mit Fehler: http.send("2=" + document.getElementById('2').value);  

Allerdings würde ich jetzt gerne, mehrere Variablen senden. Mit einem zweiten http.send funktioniert es _nicht_.

Firefox sagt mir:
Fehler: uncaught exception: [Exception... "Component returned failure code: 0x80004005 (NS_ERROR_FAILURE) [nsIXMLHttpRequest.send]"  nsresult: "0x80004005 (NS_ERROR_FAILURE)"  location: "JS frame :: calc.html :: submitForm :: line 26"  data: no]

Wie kann ich also jetzt 2 Werte senden, bzw. am besten gleich ein alle Werte aus einem Formular?

Grüße
Steffen.

  1. Hallo,
    hab es teilweise gelöst:

      
    var post = "1=" + document.getElementById('1').value+"&2=" + document.getElementById('2').value;  
    http.send(post);  
    
    

    Jetzt ist aber die Frage, wie ich alle Felder aus einem Formular auslesen und so übertragen kann.

    Grüße
    Steffen

  2. Hallo,

    Wie kann ich also jetzt 2 Werte senden, bzw. am besten gleich ein alle Werte aus einem Formular?

    Lies mal XML in the Browser: Submitting forms using AJAX.

    MfG, Thomas

    1. Hallo,

      Lies mal XML in the Browser: Submitting forms using AJAX.

      //use single quotes for argument so that the value of
      //fobj.elements[i].value is treated as a string not a literal
      cmd = valFunc + "(" + 'fobj.elements[i].value' + ")";
      val = eval(cmd)

      Uhh, schlechter Stil.

      Funktionen sind Objekte, man kann sie einer Funktion als Parameter übergeben:

      function validate (value) {
         ...
      }
      ...
      function sub (f) {
         ...
         var str = getFormValues(f, validate);
         ...
      }
      function getFormValues (fobj, valFunc) {
         ...
         valFunc(fobj.elements[i].value);
         ...
      }

      <input type="button" value="Request Information" onClick="sub(this.form)">
      In Zeiten von unobtrusive JavaScript ziemlich obsolet, es gibt ja onsubmit und DOM.

      Des Weiteren ist es nicht so trivial, einen ordentlichen application/x-www-form-urlencoded-kodierten HTTP-Body auf Formularfeldern zusammenzubauen.

      str += fobj.elements[i].name + "=" + escape(fobj.elements[i].value) + "&";

      Ist nicht so wunderbar. escape("€") bringt z.B. lustige Dinge wie %u20AC, womit man auf der Serverseite wirklich nichts mit anfangen kann. escape("ö") bringt %F6 (also ISO-8859-1-kodiert), was aber Unsinn ist, wenn man Content-Type: application/x-www-form-urlencoded; charset=UTF-8 senden will.

      Siehe mein Beispiel zu Formular in Echtzeit speichern (ist das Forumsarchiv nicht toll? man muss nur suchen).

      Mathias

  3. Hi,

    Ergänzend zum bereits gesagten:

    document.getElementById('1')

      
    darf eigentlich kein Element finden. Denn 1 ist kein gültiger Wert für eine id (die mit einem Buchstaben beginnen \_muß\_).  
      
    cu,  
    Andreas
    
    -- 
    [Warum nennt sich Andreas hier MudGuard?](http://www.Mud-Guard.de/)  
    [Schreinerei Waechter](http://www.schreinerei-waechter.de/)  
      
    Fachfragen per E-Mail halte ich für unverschämt und werde entsprechende E-Mails nicht beantworten. Für Fachfragen ist das Forum da.