이번에는 Ajax()와 백엔드 간의 상호 작용 단계에 대해 자세히 설명하겠습니다. Ajax()와 백엔드 간의 상호 작용에 대한 주의 사항은 무엇입니까? .
Ajax는 "Asynchronous JavaScript and XML"(비동기 JavaScript 및 XML)을 의미하며 대화형 웹 애플리케이션을 만들기 위한 웹 개발 기술을 나타냅니다. Ajax 기술은 현재 JavaScript 스크립트를 통해 브라우저에서 사용할 수 있는 모든 기술의 모음입니다. Ajax는 이러한 모든 기술을 새로운 방식으로 사용하여 웹 개발의 기존 B/S 스타일을 활성화합니다.
ajax() 메서드는 HTTP 요청을 통해 원격 데이터를 로드하는 jQuery의 기본 ajax 구현입니다.
$.ajax({ type: "GET", url: "handleAjaxRequest.action", data: {paramKey:paramValue}, async: true, dataType:"json", success: function(returnedData) { alert(returnedData); //请求成功后的回调函数 //returnedData--由服务器返回,并根据 dataType 参数进行处理后的数据; //根据返回的数据进行业务处理 }, error: function(e) { alert(e); //请求失败时调用此函数 } }); }
매개변수 설명:
유형: 요청 방법, "POST" 또는 "GET", 기본값은 "GET"입니다.
url: 요청을 보낼 주소입니다.
데이터: 서버로 전송할 데이터는 키:값(id:1) 형식으로 작성됩니다. GET 요청은 URL에 추가됩니다.
async: 기본값은 true이며, false로 설정하면 동기 요청입니다.
dataType: 서버에서 반환될 것으로 예상되는 데이터 유형이며 지정하지 않을 수 있습니다. xml, html, text 등이 있습니다.
개발 중에 위의 매개변수를 사용하면 이미 기본 요구 사항을 충족할 수 있습니다.
중국어 매개변수를 서버에 전달해야 하는 경우 URL 뒤에 매개변수를 쓰고 encodeURI로 인코딩할 수 있습니다.
var chinese = "中文"; var urlTemp = "handleAjaxRequest.action?chinese="+chinese; var url = encodeURI(urlTemp);//进行编码 $.ajax({ type: "GET", url: url,//直接写编码后的url success: function(returnedData) { alert(returnedData); //请求成功后的回调函数 //returnedData--由服务器返回,并根据 dataType 参数进行处理后的数据; //根据返回的数据进行业务处理 }, error: function(e) { alert(e); //请求失败时调用此函数 } }); }
Struts2 액션은 요청을 처리합니다:
public void handleAjaxRequest() { HttpServletRequest request = ServletActionContext.getRequest(); HttpServletResponse response = ServletActionContext.getResponse(); //设置返回数据为html文本格式 response.setContentType("text/html;charset=utf-"); response.setHeader("pragma", "no-cache"); response.setHeader("cache-control", "no-cache"); PrintWriter out =null; try { String chinese = request.getParameter("chinese"); //参数值是中文,需要进行转换 chinese = new String(chinese.getBytes("ISO--"),"utf-"); System.out.println("chinese is : "+chinese); //业务处理 String resultData = "hello world"; out = response.getWriter(); out.write(resultData); //如果返回json数据,response.setContentType("application/json;charset=utf-"); //Gson gson = new Gson(); //String result = gson.toJson(resultData);//用Gson将数据转换为json格式 //out.write(result); out.flush(); }catch(Exception e) { e.printStackTrace(); }finally { if(out != null) { out.close(); } } }
struts.xml구성 파일: 반환 유형을 작성할 필요가 없습니다
<action name="handleAjaxRequest" class="com.test.TestAction" method="handleAjaxRequest"> </action>
AJAX 프런트엔드 및 백엔드 상호 작용 방법 공유
참고: ajax는 비동기 매개변수에 의해 결정됩니다. 또는 동기식, 거짓 동기화, 참 비동기식
비동기 실행 순서는 후속 작업을 먼저 실행한 다음 성공한 코드를 실행하는 것입니다.
동기화는 성공한 코드를 먼저 실행한 다음 후속 작업을 실행하는 것입니다.
확인: 동기화 중 데이터 양이 정지되나요? 예를 들어, 백그라운드에서 많은 양의 데이터를 검색할 때 페이지가 멈추나요?
1. (비동기) 메서드 호출, 후속 코드는 실행 결과를 기다릴 필요가 없습니다
Backend
using System.Web.Script.Services; public static string GetStr(string str1, string str2) { return str1 + str2; }
Frontend
function Test(strMsg1,strMsg2) { $.ajax({ type: "Post", url: "Demo.aspx/GetStr", async: true, //方法传参的写法一定要对,与后台一致,区分大小写,不能为数组等,str1为形参的名字,str2为第二个形参的名字 data: "{'str1':'"+strMsg1+"','str2':'"+strMsg2+"'}", contentType: "application/json; charset=utf-8", dataType: "json", success: function(data) { //返回的数据用data.d获取内容 alert(data.d); }, error: function(err) { alert(err); } }); //隐藏加载动画 $("#pageloading").hide(); }
2. 필요할 때 반환 값을 얻는 것은 후속 코드를 실행하기 위한 전제 조건입니다.
Backend
using System.Web.Script.Services; public static string GetStr(string str1, string str2) { return str1 + str2; }
Frontend
function Test(strMsg1,strMsg2) { var str = “”; $.ajax({ type: "Post", url: "Demo.aspx/GetStr", async: false, //方法传参的写法一定要对,与后台一致,区分大小写,不能为数组等,str1为形参的名字,str2为第二个形参的名字 data: "{'str1':'"+strMsg1+"','str2':'"+strMsg2+"'}", contentType: "application/json; charset=utf-8", dataType: "json", success: function(data) { //返回的数据用data.d获取内容 str = data.d; }, error: function(err) { alert(err); } }); return str;
더 흥미로운 정보를 보려면 이 기사의 사례를 읽은 후 방법을 마스터했다고 생각합니다. , PHP 중국어 웹사이트 기사에서 다른 관련 주제에 주목하세요!
추천 도서:
Ajax의 페이지 새로 고침이 없는 구현에 대한 자세한 설명(코드 포함)
위 내용은 Ajax()와 상호작용하는 단계와 배경에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!