国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開(kāi)發(fā) > AJAX > 正文

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

2024-09-01 08:28:33
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

本文實(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ì)有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 黑龙江省| 剑河县| 韩城市| 罗甸县| 加查县| 吉隆县| 安塞县| 宁海县| 慈利县| 牡丹江市| 武胜县| 黄陵县| 易门县| 岐山县| 措勤县| 芦溪县| 佛坪县| 通山县| 长汀县| 黔东| 甘洛县| 即墨市| 东乌| 琼海市| 台中市| 昆山市| 永平县| 历史| 克山县| 永顺县| 广宁县| 海安县| 南和县| 忻州市| 和龙市| 万载县| 商水县| 论坛| 宁都县| 万盛区| 九龙坡区|