我所舉的這個例子是一個企業使用者註冊時的一個應用,當使用者註冊時檢查使用者名稱和企業名是否可用,以前的做法是在旁邊加一個按鈕,點擊“檢查”,就向伺服器發出請求,然後等待……伺服器返回資訊,繼續操作。如果我們用Ajax技術來實現以上的操作則不必等待伺服器返回資訊,使用者輸入使用者名稱或企業名稱的時候,當輸入文字框失去焦點的時候,則會自動向伺服器發出請求,使用者繼續做下面的操作,不必點擊“檢查”,也不必等待伺服器返回資訊,檢查與使用者操作是非同步,可同時進行。當伺服器資訊返回的時候,會自動在面頁相應位置顯示返回資訊,不必重新整理頁面,相當於局部重新整理的效果。
下面我們來看代碼吧。
HTML頁面的完整代碼如下:
1<%@page language="java" contentType="text/html;charset=GBK"%> 2<script language="javascript" type="text/javascript"> 3<!-- 4/**//**Ajax 開始 by Alpha 2005-12-31*/ 5 6 var http = getHTTPObject(); 7 8 function handleHttpResponse(){ 9 if(http.readyState == 4){ 10 if(http.status == 200){ 11 var xmlDocument = http.responseXML; 12 if(http.responseText!=""){ 13 document.getElementById("showStr").style.display = ""; 14 document.getElementById("userName").style.background= "#FF0000"; 15 document.getElementById("showStr").innerText = http.responseText; 16 }else{ 17 document.getElementById("userName").style.background= "#FFFFFF"; 18 document.getElementById("showStr").style.display = "none"; 19 } 20 21 } 22 else{ 23 alert("你所請求的頁面發生異常,可能會影響你瀏覽該頁的資訊!"); 24 alert(http.status); 25 } 26 } 27 } 28 29 function handleHttpResponse1(){ 30 if(http.readyState == 4){ 31 if(http.status == 200){ 32 var xmlDocument = http.responseXML; 33 if(http.responseText!=""){ 34 document.getElementById("comNmStr").style.display = ""; 35 document.getElementById("comNm").style.background= "#FF0000"; 36 document.getElementById("comNmStr").innerText = http.responseText; 37 }else{ 38 document.getElementById("comNm").style.background= "#FFFFFF"; 39 document.getElementById("comNmStr").style.display = "none"; 40 } 41 42 } 43 else{ 44 alert("你所請求的頁面發生異常,可能會影響你瀏覽該頁的資訊!"); 45 alert(http.status); 46 } 47 } 48 } 49 50 function chkUser(){ 51 var url = "/chkUserAndCom"; 52 var name = document.getElementById("userName").value; 53 url += ("&userName="+name+"&oprate=chkUser"); 54 http.open("GET",url,true); 55 http.onreadystatechange = handleHttpResponse; 56 http.send(null); 57 return ; 58 } 59 function chkComNm(){ 60 var url = "/chkUserAndCom"; 61 var name = document.getElementById("comNm").value; 62 url += ("&comName="+name+"&oprate=chkCom"); 63 http.open("GET",url,true); 64 http.onreadystatechange = handleHttpResponse1; 65 http.send(null); 66 return ; 67 } 68 69 //該函數可以建立我們需要的XMLHttpRequest對象 70 function getHTTPObject(){ 71 var xmlhttp = false; 72 if(window.XMLHttpRequest){ 73 xmlhttp = new XMLHttpRequest(); 74 if(xmlhttp.overrideMimeType){ 75 xmlhttp.overrideMimeType('text/xml'); 76 } 77 } 78 else{ 79 try{ 80 xmlhttp = new ActiveXObject("Msxml2.XMLHTTP"); 81 }catch(e){ 82 try{ 83 xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); 84 }catch(E){ 85 xmlhttp = false; 86 } 87 } 88 } 89 return xmlhttp; 90 } 91/**//**Ajax 結束*/ 92 93//檢測表單 94function chkpassword() 95{ 96 var m=document.form1; 97 if(len(m.password.value) > 20 || len(m.password.value) < 5 || !isStr(m.password.value)) 98 { 99 document.getElementById("passwordStr").style.display = ""; 100 document.getElementById("password").style.background= "#FF0000"; 101 document.getElementById("passwordStr").innerText = "對不起,密碼必須為英文字母、數字或底線,長度為5~20!"; 102 } 103 else 104 { 105 document.getElementById("password").style.background= "#FFFFFF"; 106 document.getElementById("passwordStr").style.display = "none"; 107 } 108} 109 110function chkconfirmPassword() 111{ 112 var m=document.form1; 113 if (m.password.value != m.confirmPassword.value) 114 { 115 document.getElementById("confirmPasswordStr").style.display = ""; 116 document.getElementById("confirmPassword").style.background= "#FF0000"; 117 document.getElementById("confirmPasswordStr").innerText = "對不起,密碼與重複密碼不一致!"; 118 } 119 else 120 { 121 document.getElementById("confirmPassword").style.background= "#FFFFFF"; 122 document.getElementById("confirmPasswordStr").style.display = "none"; 123 } 124} 125 126function checkfield() 127{ 128 var m=document.form1; 129 if(m.userName.value.length==0) 130 { 131 alert("對不起,使用者名稱必須為英文字母、數字或底線,長度為5~20。"); 132 m.userName.focus(); 133 return false; 134 } 135 if(m.password.value.length==0) 136 { 137 alert("對不起,密碼必須為英文字母、數字或底線,長度為5~20。"); 138 m.password.focus(); 139 return false; 140 } 141 if (m.password.value != m.confirmPassword.value) 142 { 143 alert("對不起,密碼與重複密碼不一致!"); 144 m.confirmPassword.focus(); 145 return false; 146 } 147 if(m.comNm.value.length==0) 148 { 149 alert("對不起,企業名稱不可為空!!"); 150 m.comNm.focus(); 151 return false; 152 } 153 m.submit(); 154} 155 156//--> 157</script> 158<body topmargin="0"> 159<form name="form1" method="post" action="/Control?act=Register"> 160<table width="100%"> 161 <tr><td align="center"> <H2>Ajax 示範程式</H1></td></tr> 162 <tr><td align="center"> ------ 企業註冊 By Alpha</td></tr> 163</table> 164 165<HR> 166 <table width="400" border="0" cellpadding="1" cellspacing="1" align="center" > 167 <tr> 168 <td><font color="red">*</font></td> 169 <td>使用者帳號:</td> 170 <td> 171 <input type="text" name="userName" maxlength="20" style="background:#FFFFFF" onBlur="chkUser()" value=""/> 172 <div id="showStr" style="background-color:#FF9900;display:none"></div> 173 </td> 174 </tr> 175 <tr> 176 <td><font color="red">*</font></td> 177 <td>企業名稱:</td> 178 <td> 179 <input type="text" name="comNm" maxlength="100" style="background:#FFFFFF" onBlur="chkComNm()" value=""/> 180 <div id="comNmStr" style="background-color:#FF9900;display:none"></div> 181 182 </td> 183 </tr> 184 <tr> 185 <td><font color="red">*</font></td> 186 <td>使用者密碼:</td> 187 <td><input type="password" name="password" maxlength="20" style="background:#FFFFFF" onBlur="chkpassword()"/> 188 <div id="passwordStr" style="background-color:#FF9900;display:none"></div> 189 </td> 190 </tr> 191 <tr> 192 <td><font color="red">*</font></td> 193 <td>確認密碼:</td> 194 <td><input type="password" name="confirmPassword" maxlength="20" style="background:#FFFFFF" onBlur="chkconfirmPassword()"/> 195 <div id="confirmPasswordStr" style="background-color:#FF9900;display:none"></div> 196 </td> 197 </tr> 198 </table> 199 200 <div align="center"> 201 <input type="button" name="ok" value=" 確 定 " onclick="checkfield()"> 202 203 <input type="reset" name="reset" value=" 取 消 "> 204 </div> 205 206</form> 207</body> 208</html> |
用JavaScript來建立XMLHttpRequest 類向伺服器發送一個HTTP請求後,接下來要決定當收到伺服器的響應後,需要做什麼。這需要告訴HTTP請求對象用哪一個JavaScript函數處理這個響應。可以將對象的onreadystatechange屬性設定為要使用的JavaScript的函數名,如下所示:xmlhttp_request.onreadystatechange =FunctionName;
FunctionName是用JavaScript建立的函數名,注意不要寫成FunctionName(),當然我們也可以直接將JavaScript代碼建立在onreadystatechange之後。