AJAX 제출 양식 데이터 예시 분석

亚连
풀어 주다: 2018-05-25 10:50:48
원래의
1550명이 탐색했습니다.

이 글에서는 AJAX로 폼 데이터를 제출하는 방법을 주로 소개합니다. 예제에서는 Ajax 호출의 원리와 구현 기술을 분석합니다. 필요한 친구가 참고할 수 있습니다.

이 글의 예에서는 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);
로그인 후 복사

Front-end call

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

위는 제가 모두를 위해 컴파일한 것입니다. 앞으로 모든 사람에게 도움이 되기를 바랍니다.

관련 기사:

Asp.net MVC에서 Ajax 사용에 대한 간략한 분석

JQuery Ajax는 JSON 데이터를 얻기 위해 AJAX 교차 도메인 요청을 위한 테이블

JSONP를 동적으로 생성합니다

위 내용은 AJAX 제출 양식 데이터 예시 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!