濮阳杆衣贸易有限公司

主頁 > 知識庫 > AJAX提交表單數(shù)據(jù)實例分析

AJAX提交表單數(shù)據(jù)實例分析

熱門標(biāo)簽:百靈鳥 青海醫(yī)療智能外呼系統(tǒng)怎么樣 外呼系統(tǒng)獲取客戶手機號 上海浦東百度地圖標(biāo)注中心注冊 老虎郵局地圖標(biāo)注點 科智聯(lián)智能電銷機器人 目標(biāo)三維地圖標(biāo)注 襄陽外呼系統(tǒng)接口 徐州電銷卡外呼系統(tǒng)供應(yīng)商

本文實例講述了AJAX提交表單數(shù)據(jù)的方法。分享給大家供大家參考。具體如下:

var TINY={}; 
TINY.ajax = function() { 
 return { 
   /** 
   * @param string type 請求類型,post,get(目前只實現(xiàn)了這兩種) 
   * @param strng url 請求的地址 
   * @param object data 當(dāng)使用post請求時的請求參數(shù),ex: data=> {name:'adam'} 
   * @param function callback 成功返回時的回調(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格式

這里對CheckBox復(fù)選框做了特殊處理,后臺接收到的該值為所有復(fù)選框值用逗號的拼接

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");
}

希望本文所述對大家的Ajax程序設(shè)計有所幫助。

您可能感興趣的文章:
  • 防止ajax重復(fù)請求的方法(GET和POST)
  • AJAX避免用戶重復(fù)提交請求實現(xiàn)方案
  • ajax 防止用戶反復(fù)提交的2種解決方案
  • 防止重復(fù)發(fā)送Ajax請求的解決方案
  • PHP中如何防止外部惡意提交調(diào)用ajax接口

標(biāo)簽:紅河 股票 辛集 揭陽 佛山 荊州 咸寧 商洛

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《AJAX提交表單數(shù)據(jù)實例分析》,本文關(guān)鍵詞  AJAX,提交,表單,數(shù)據(jù),實例分析,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《AJAX提交表單數(shù)據(jù)實例分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于AJAX提交表單數(shù)據(jù)實例分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    托克逊县| 苍梧县| 瓮安县| 民权县| 乐至县| 乌审旗| 惠水县| 伊通| 南安市| 道真| 祁阳县| 洪江市| 菏泽市| 洛扎县| 柳河县| 昭苏县| 中宁县| 宿松县| 永善县| 外汇| 涡阳县| 嵊泗县| 土默特右旗| 沧州市| 常熟市| 家居| 吉木萨尔县| 五峰| 历史| 克东县| 湖南省| 科尔| 浮梁县| 古丈县| 蕉岭县| 宝丰县| 桐柏县| 师宗县| 高要市| 周宁县| 瑞金市|