AJAX提交表單數(shù)據(jù)實(shí)例分析
本文實(shí)例講述了AJAX提交表單數(shù)據(jù)的方法。分享給大家供大家參考。具體如下:
var TINY={};
TINY.ajax = function() {
return {
/**
* @param string type 請(qǐng)求類型,post,get(目前只實(shí)現(xiàn)了這兩種)
* @param strng url 請(qǐng)求的地址
* @param object data 當(dāng)使用post請(qǐng)求時(shí)的請(qǐng)求參數(shù),ex: data=> {name:'adam'}
* @param function callback 成功返回時(shí)的回調(diào)函數(shù)
*/
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;
}
}
}
}();
遍歷表單各元素,將參數(shù)值組織成JSON格式
這里對(duì)CheckBox復(fù)選框做了特殊處理,后臺(tái)接收到的該值為所有復(fù)選框值用逗號(hào)的拼接
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的調(diào)用:
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);
}
});
談到服務(wù)器端返回的JSON格式數(shù)據(jù),支持如下格式
String str = "[{\"mailAddr\":\"edison@163.com\"}, {\"mailAddr\":\"jay@263.com\"}]";
response.setContentType("application/json;charset=UTF-8");
response.getWriter().write(str);
前端調(diào)用
function show(){
$.post("listmail.do", {"name" : "John"}, function(data){
for(var i = 0; i < data.length; i++){
alert(data[i].mailAddr);
}
}, "json");
}
希望本文所述對(duì)大家的Ajax程序設(shè)計(jì)有所幫助。
相關(guān)文章
簡(jiǎn)單實(shí)體類和xml文件的相互轉(zhuǎn)換方法
下面小編就為大家?guī)硪黄?jiǎn)單實(shí)體類和xml文件的相互轉(zhuǎn)換方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08
AJAX實(shí)現(xiàn)數(shù)據(jù)的增刪改查操作詳解【java后臺(tái)】
這篇文章主要介紹了AJAX實(shí)現(xiàn)數(shù)據(jù)的增刪改查操作,結(jié)合實(shí)例形式詳細(xì)分析了ajax結(jié)合java后臺(tái)實(shí)現(xiàn)數(shù)據(jù)庫(kù)增刪改查相關(guān)操作技巧,需要的朋友可以參考下2020-06-06
基于Ajax技術(shù)實(shí)現(xiàn)無刷新用戶登錄功能
這篇文章主要介紹了基于Ajax技術(shù)實(shí)現(xiàn)無刷新用戶登錄功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下吧2017-01-01
Jquery基于Ajax方法自定義無刷新提交表單Form實(shí)例
這篇文章主要介紹了Jquery基于Ajax方法自定義無刷新提交表單Form的方法,結(jié)合實(shí)例詳細(xì)分析了Ajax無刷新提交表單的完整實(shí)現(xiàn)過程,并總結(jié)了使用中的注意事項(xiàng),具有很好的借鑒價(jià)值,需要的朋友可以參考下2014-11-11
bootstrap select2 動(dòng)態(tài)從后臺(tái)Ajax動(dòng)態(tài)獲取數(shù)據(jù)的代碼
這篇文章主要介紹了bootstrap select2 動(dòng)態(tài)從后臺(tái)Ajax動(dòng)態(tài)獲取數(shù)據(jù)的代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12
springmvc 結(jié)合ajax批量新增的實(shí)現(xiàn)方法
這篇文章主要介紹了springmvc 結(jié)合ajax批量新增的實(shí)現(xiàn)方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11
如何通過axios發(fā)起Ajax請(qǐng)求(最新推薦)
Axios是專注于網(wǎng)絡(luò)數(shù)據(jù)請(qǐng)求的庫(kù),相比于原生的XMLHttpRequest對(duì)象,axios簡(jiǎn)單易用。相比于Jquery,axios更加輕量化,只專注于網(wǎng)絡(luò)數(shù)據(jù)請(qǐng)求,這篇文章主要介紹了如何通過axios發(fā)起Ajax請(qǐng)求,需要的朋友可以參考下2022-11-11

