Home >Web Front-end >JS Tutorial >Ajax overview and implementation
This time I will bring you an overview and implementation of Ajax. What are the precautions for Ajax overview and implementation? The following is a practical case, let's take a look.
Ajax is the abbreviation of Asynchronous1. Overview of ajax
1. Ajax is Asynchronous ([ə'sɪŋkrənəs) JavaScript XML In short, it is not a new technology, but the comprehensive utilization of existing technologies. This technology can request additional data from the server without refreshing the page, bringing a better user experience2. The core of Ajax technology is the XMLHttpRequest object (XHR for short), which was first introduced by Microsoft characteristic. Before the advent of XHR, Ajax-style communication had to be achieved with some hacks, mostly using hidden frames or inline frames. 3. XHR provides a smooth interface for sending requests to the server and parsing server responses. Being able to obtain more information from the server asynchronously means that after the user clicks, new data can be obtained without refreshing the page. That is to say, you can use the XHR object to obtain new data, and then insert the new data into the page through the DOM4. Although the Ajax name contains XML components, Ajax communication has nothing to do with the data format. This technology is to obtain data from the server without refreshing the page, but it is not necessarily XML data2. Operation: native ajax and ajax encapsulated in jQuery
1 , Native ajax: Ajax function: Send request (set request setRequest) Receive response (getResponse)A. Send request in ajax native way: The most important thing in Ajax is also The most fixed part is the http request. 1) Establish a connection: (IE7 and above versions support XMLHttpRequest)var xhr = new XMLHttpRequest(); //Create an asynchronous request object
xhr.open("get","01-register.php?name="+name);//初始化异步get请求 xhr.send(null); //与服务器建立连接3)
xhr.open('post','01-XMLHTTPRequest-test.php');//请求报文行 xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded'); /*post请求设置请求头*/ xhr.send('name=rose&age=20'); //请求报文体4)get and post request Difference: ★get does not need to set the request header, while post needs to set the request header★The data of get is passed through the url, while the data of post is passed in the send methodB. Receive response in ajax native way:
/*监听服务器的响应*/ xhr.onreadystatechange=function(){ /*判断当前的响应是否成功 1.服务器做出了响应 2.响应的结果是正确的*/ if(xhr.status==200 && xhr.readyState==4){ var result=xhr.responseText; console.log(result); //输出从服务器中获取到的数据 //接下来就可以对数据进行相应的处理了 } };C. Process response data:
/*监听*/ xhr.onreadystatechange=function(){ if(xhr.status==200 && xhr.readyState==4){ /*判断状态*/ var result; /*获取响应报文中的Content-Type*/ var ct=xhr.getResponseHeader("Content-Type"); /*判断Content-Type,进行数据的解析*/ if(ct.indexOf("xml") != -1){ result=xhr.responseXML; } else if(ct.indexOf("json") !=-1){ result=JSON.parse(xhr.responseText); } else{ result=xhr.responseText; } /*调用回调函数--委托--代理*/ success && success(result); } };Ajax encapsulated in jQuery
$.ajax({ type: 请求方式(get/post), url: "register.php", data: 发送请求数据, beforeSend:function(){返回false可以取消本次ajax请求}, success:function(result){ 成功响应后调用 }, error:function(err){ 错误响应时调用 }, complete:function(){ 响应完成时调用(包括成功和失败) } });jQuery provides special methods to Serialize form:
$('form').serialize(): //Serialize form (i.e. format key=val & key=val);
3. Response
We need to monitor the response status of the server, and then process the data obtained from the server accordingly. 1) onreadystatechange is one of theJavaScript events, used to monitor the status of XMLHttpRequest
2) readystate: response status, returns the current status of the XMLHTTP requestreadyState State |
State description |
(0) Not initialized | This phase confirms whether the XMLHttpRequest object is created and calls the open() method Be prepared for uninitialization. A value of 0 indicates that the object already exists, otherwise the browser will report an error - the object does not exist. |
(1) Loading | At this stage, the XMLHttpRequest object is initialized, that is, the open() method is called. Complete the setting of the object status according to the parameters (method, url, true). And call the send() method to start sending requests to the server. A value of 1 indicates that a request is being sent to the server. |
(2)Loading completed | This stage receives the response data from the server. But what is obtained is only the original data of the server response, and cannot be used directly on the client. A value of 2 indicates that all response data has been received. And prepare for the next stage of data analysis. |
(3) Interaction |
This stage parses the received server-side response data. That is, according to the MIME type returned by the server-side response header, the data is converted into a format that can be accessed through the responseBody, responseText or responseXML attributes, so as to be ready for invocation on the client. Status 3 indicates that the data is being parsed. |
(4)Complete |
This stage confirms that all data has been parsed into a format usable by the client. Has been completed. A value of 4 indicates that the data parsing is complete and the data can be obtained through the corresponding attributes of the XMLHttpRequest object. |
3) Status: Server response code
Common response code: 200—The server successfully returned the web page
404— The requested web page does not exist
503—Service Unavailable
For details about the server response code, please see————Network Transfer Protocol (http protocol)
I believe you have read this article You have mastered the case method. For more exciting information, please pay attention to other related articles on the PHP Chinese website!
Recommended reading:
Implementation of ajax login function
##Ajax implementation of asynchronous loading
The above is the detailed content of Ajax overview and implementation. For more information, please follow other related articles on the PHP Chinese website!