AJAX提交表單資料執行個體分析_AJAX相關

來源:互聯網
上載者:User

本文執行個體講述了AJAX提交表單資料的方法。分享給大家供大家參考。具體如下:

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

遍曆表單各元素,將參數值組織成JSON格式

這裡對CheckBox複選框做了特殊處理,後台接收到的該值為所有複選框值用逗號的拼接

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的調用:

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

談到伺服器端返回的JSON格式資料,支援如下格式

String str = "[{\"mailAddr\":\"edison@163.com\"}, {\"mailAddr\":\"jay@263.com\"}]";response.setContentType("application/json;charset=UTF-8");response.getWriter().write(str);

前端調用

function show(){  $.post("listmail.do", {"name" : "John"}, function(data){  for(var i = 0; i < data.length; i++){   alert(data[i].mailAddr);  } }, "json");}

希望本文所述對大家的Ajax程式設計有所協助。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.