AJAX: Ganzes Formular senden
Steffen
- javascript
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.
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
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
Hallo,
//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
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.