用JavaScript實現的Ajax

JavaScript實現的Ajax,在性能上要比使用jQuery的ajax方法快一些,,因此說通常狀況下,,我的建議仍是我的用javascript實現ajax請求較好,javascript主要是利用XMLHttpRequest對象發送異步請求,首先須要定義XMLHttpRequest對象:javascript

 

[javascript] view plain copy
 
  1. <script type="text/javascript">  
  2. //定義XMLHttpRequest對象  
  3. if(window.XMLHttpRequest){  
  4.     //兼容Mozilla、Safari等非IE瀏覽器  
  5.     var xmlhttprequest = new XMLHttpRequest();  
  6. }else{  
  7.     if(window.ActiveXObject){  
  8.         //兼容IE瀏覽器  
  9.         try{  
  10.             var xmlhttprequest = new ActiveXObject('Msxml12.XMLHTTP');  
  11.         }catch(e){  
  12.             try{  
  13.                 xmlhttprequest = new ActiveXObject('Microsoft.XMLHTTP');  
  14.             }catch(e){  
  15.             }  
  16.         }  
  17.     }  
  18. }  
  19. </script>  

而後就是使用該對象,在這裏定義了兩個,一個是GET方式發送,一個是POST方式發送:html

 

GET方式:java

 

[javascript] view plain copy
 
  1. function jsAjaxGet(){  
  2.     var ul = document.getElementById("jsajaxget");  
  3.     //調用XMLHttpRequest對象的open方法,打開與服務器之間的同步通訊鏈接  
  4.       
  5.     /** 
  6.      * 創建異步鏈接 
  7.      * xmlhttprequest.open(Method,Url,Async,User,Password)方法 
  8.      * Method:表示Http方法,POST,GET,PUT,PROPFIND 
  9.      * Url:參數請求的url 
  10.      * Async:可選項,設置是否爲異步通訊, 
  11.      *      默認true表示能夠異步, 
  12.      *      取false,代表異步發出請求以後不須要等待服務端的響應,繼續執行其餘操做。 
  13.      * User,password:可選項,表示請求的文件須要進行服務器進行驗證 
  14.      */  
  15.     xmlhttprequest.open("GET","Ajax_javascript.action",false);  
  16.     /** 
  17.      * 向服務器發送請求 
  18.      * xmlhttprequest.send(null) 
  19.      * 只有一個參數,該參數傳遞客戶端發送給服務器的請求數據 
  20.      * 該方法通常是在POST方式下傳遞參數,多個參數用&隔開 
  21.      */  
  22.     xmlhttprequest.send(null);  
  23.       
  24.     ul.innerHTML += "<li>status:" + xmlhttprequest.status + "</li>";  
  25.     ul.innerHTML += "<li>statusText:" + xmlhttprequest.statusText + "</li>";  
  26.     ul.innerHTML += "<li>return:" + xmlhttprequest.responseText + "</li>";  
  27. }  

POST方式:jquery

 

 

[javascript] view plain copy
 
  1. function jsAjaxPost(){  
  2.     var ul = document.getElementById("jsajaxpost");  
  3.     //調用XMLHttpRequest對象的open方法,打開與服務器之間的同步通訊鏈接  
  4.       
  5.     /** 
  6.      * 創建異步鏈接 
  7.      * xmlhttprequest.open(Method,Url,Async,User,Password)方法 
  8.      * Method:表示Http方法,POST,GET,PUT,PROPFIND 
  9.      * Url:參數請求的url 
  10.      * Async:可選項,設置是否爲異步通訊, 
  11.      *      默認true表示能夠異步, 
  12.      *      取false,代表異步發出請求以後不須要等待服務端的響應,繼續執行其餘操做。 
  13.      * User,password:可選項,表示請求的文件須要進行服務器進行驗證 
  14.      */  
  15.     xmlhttprequest.open("POST","Ajax_javascript.action",false);  
  16.     /** 
  17.      * 設置請求的消息頭 
  18.      * application/x-www-form-urlencoded表示傳遞的是表單值 
  19.      * 通常使用POST都必須設置此項,不然服務器沒法識別傳遞過來的數據 
  20.      * 雖然該值表示表單值,可是也能夠一text/xml或者application/xml類型給服務器直接發送XML數據 
  21.      * 甚至也能夠application/json類型發送JavaScript對象數據 
  22.      */  
  23.     xmlhttprequest.setRequestHeader('Content-type','application/x-www-form-urlencoded');  
  24.     /** 
  25.      * 設置User-Agent爲XMLHTTP便於服務器可以識別出XMLHttpRequest異步請求 
  26.      * 和其餘客戶端的普通請求 
  27.      */  
  28.     xmlhttprequest.setRequestHeader('User-Agent','XMLHTTP');  
  29.        
  30.     /** 
  31.      * 向服務器發送請求 
  32.      * xmlhttprequest.send(null) 
  33.      * 只有一個參數,該參數傳遞客戶端發送給服務器的請求數據 
  34.      * 該方法通常是在POST方式下傳遞參數,多個參數用&隔開 
  35.      */  
  36.     xmlhttprequest.send("user=goomoon&com=fantong");  
  37.       
  38.     ul.innerHTML += "<li>status:" + xmlhttprequest.status + "</li>";  
  39.     ul.innerHTML += "<li>statusText:" + xmlhttprequest.statusText + "</li>";  
  40.     ul.innerHTML += "<li>return:" + xmlhttprequest.responseText + "</li>";  
  41. }  

寫完ajax方法以後,接下來就是定義了鏈接了:ajax

 

 

[html] view plain copy
 
  1. <ul>  
  2.     <li>  
  3.         <href="javascript:jsAjaxGet();">(GET)javascript ajax testing.</a>  
  4.         <ul id="jsajaxget"></ul>  
  5.     </li>  
  6.     <li>  
  7.         <href="javascript:jsAjaxPost();">(POST)javascript ajax testing.</a>  
  8.         <ul id="jsajaxpost"></ul>  
  9.     </li>  
  10. </ul>  

提交的Url是struts2實現的action類,繼承自com.opensymphony.xwork2.ActionSupport,主要代碼以下:json

[java] view plain copy
 
  1. public String javascript() throws IOException{  
  2.       
  3.     HttpServletResponse response = ServletActionContext.getResponse();  
  4.     PrintWriter out = response.getWriter();  
  5.       
  6.     out.print("com:"+com+",");  
  7.     out.print("user:"+user+",");  
  8.     out.print("the ajax testing is success");  
  9.     out.flush();  
  10.     out.close();  
  11.     return NONE;  
  12. }  

最後輸出結果圖爲:瀏覽器

 

轉載文章,感謝原博主:http://blog.csdn.net/lzkkevin/article/details/6777474。服務器

相關文章
相關標籤/搜索