Ajax()와 상호작용하는 단계와 배경에 대한 자세한 설명

php中世界最好的语言
풀어 주다: 2018-04-04 17:46:42
원래의
2271명이 탐색했습니다.

이번에는 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 중국어 웹사이트 기사에서 다른 관련 주제에 주목하세요!

추천 도서:

Django에서 Ajax를 사용하는 방법

Ajax의 페이지 새로 고침이 없는 구현에 대한 자세한 설명(코드 포함)

위 내용은 Ajax()와 상호작용하는 단계와 배경에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿