Heim >Web-Frontend >js-Tutorial >Beispielanalyse für AJAX-Übermittlungsformulardaten
Dieser Artikel stellt hauptsächlich die Methode der AJAX-Übermittlung von Formulardaten vor. Das Beispiel analysiert das Prinzip und die Implementierungsfähigkeiten von Ajax-Aufrufen.
Das Beispiel dieses Artikels beschreibt die Methode AJAX-Übermittlung von Formulardaten. Teilen Sie es als Referenz mit allen. Die Details lauten wie folgt:
var TINY={}; TINY.ajax = function() { return { /** * @param string type 请求类型,post,get(目前只实现了这两种) * @param strng url 请求的地址 * @param object data 当使用post请求时的请求参数,ex: data=> {name:'adam'} * @param function callback 成功返回时的回调函数 */ call : function(type, url, data, callback) { var xhr = window.XMLHttpRequest ? new XMLHttpRequest : new ActiveXObject('Microsoft.XMLHTTP');// for ie xhr.onreadystatechange = function() { if (xhr.readyState == 4 && xhr.status == 200) { callback.call(this, xhr.responseText); } } switch (type.toUpperCase()) { case 'POST': xhr.open('POST', url, true); // 这句比较重要 xhr.setRequestHeader('Content-type', 'application/x-www-form-urlencoded'); var formData = ''; for ( var i in data) { formData += i + '=' + data[i] + '&'; } xhr.send(formData); break; default: xhr.open('GET', url, true); xhr.send(null) break; } } } }();
Durchlaufen Sie jedes Element des Formulars und organisieren Sie die Parameterwerte im JSON-Format
Hier erfolgt eine spezielle Verarbeitung für das Kontrollkästchen CheckBox und den empfangenen Wert im Hintergrund ist für alle Kontrollkästchen Werte mit Kommas verbunden
function serialForm(form){ var e = form.elements; var ht = new Array(); var checkbox = new Array(); for(var i = 0; i < e.length; i++) { if(e[i].type=="checkbox"){ if(e[i].checked){ if(checkbox[e[i].name] != null) checkbox[e[i].name].push(e[i].value); else checkbox[e[i].name] = [e[i].value]; } } else { ht.push(e[i].name+":'"+e[i].value+"'"); ht.push(","); } } for (var ddd in checkbox ){ ht.push(ddd + ":'" + checkbox[ddd] + "'"); ht.push(","); } ht.push("nt:0"); return eval('({' + ht.join("") + '})'); };
AJAX-Aufruf:
TINY.ajax.call('post', 'listfrom.do', serialForm(frm), function(data){ var ret = eval('('+data+')'); if(ret.errid==0){ alert(ret.text); window.location.reload(); } else{ alert(ret.text); } });
Apropos JSON-Formatdaten, die vom Server zurückgegeben werden: Die folgenden Formate werden unterstützt
String str = "[{\"mailAddr\":\"edison@163.com\"}, {\"mailAddr\":\"jay@263.com\"}]"; response.setContentType("application/json;charset=UTF-8"); response.getWriter().write(str);
Front-End-Anruf
function show(){ $.post("listmail.do", {"name" : "John"}, function(data){ for(var i = 0; i < data.length; i++){ alert(data[i].mailAddr); } }, "json"); }
Das oben Gesagte habe ich für Sie zusammengestellt. Ich hoffe, es wird Ihnen in Zukunft hilfreich sein.
Verwandte Artikel:
Eine kurze Analyse der Verwendung von Ajax in Asp.net MVC
JQuery Ajax generiert dynamisch Tabellen
JSONP für domänenübergreifende AJAX-Anfrage zum Abrufen von JSON-Daten
Das obige ist der detaillierte Inhalt vonBeispielanalyse für AJAX-Übermittlungsformulardaten. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!