AJAX Êý¾Ý¿âʵÀý
AJAX ¿ÉÓÃÀ´ÓëÊý¾Ý¿â½øÐÐÏ໥µÄͨÐÅ¡£
AJAX Êý¾Ý¿âʵÀý
ÏÂÃæµÄÀý×ÓÑÝÊ¾ÍøÒ³ÈçºÎͨ¹ý AJAX ´ÓÊý¾Ý¿âÖжÁÈ¡ÐÅÏ¢£º
¿Í»§ÐÅÏ¢½«ÔÚ´Ë´¦Áгö¡£
ʵÀý½âÊÍ - HTML Ò³Ãæ
µ±Óû§ÔÚÉÏÃæµÄÏÂÀÁбíÖÐÑ¡Ôñijλ¿Í»§Ê±£¬»áÖ´ÐÐÃûΪ "showCustomer()" µÄº¯Êý¡£¸Ãº¯ÊýÓÉ "onchange" ʼþ´¥·¢£º
<!DOCTYPE html>
<html>
<head>
<script>
function showCustomer(str)
{
if (str=="")
{
document.getElementById("txtHint").innerHTML="";
return;
}
if (window.XMLHttpRequest)
{// Õë¶Ô IE7+, Firefox, Chrome, Opera, Safari µÄ´úÂë
xmlhttp=new XMLHttpRequest();
}
else
{// Õë¶Ô IE6, IE5 µÄ´úÂë
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange=function()
{
if (xmlhttp.readyState==4 && xmlhttp.status==200)
{
document.getElementById("txtHint").innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET","getcustomer.asp?q="+str,true);
xmlhttp.send();
}
</script>
</head
<body>
<form>
<select name="customers" onchange="showCustomer(this.value)">
<option value="">Select a customer:</option>
<option value="ALFKI">Alfreds Futterkiste</option>
<option value="NORTS ">North/South</option>
<option value="WOLZA">Wolski Zajazd</option>
</select>
</form>
<br>
<div id="txtHint">¿Í»§ÐÅÏ¢½«ÔÚ´Ë´¦Áгö...</div>
</body>
</html>
Ô´´úÂë½âÊÍ£º
Èç¹ûûÓÐÑ¡Ôñ¿Í»§£¨str.length µÈÓÚ 0£©£¬ÄÇô¸Ãº¯Êý»áÇå¿Õ txtHint ռλ·û£¬È»ºóÍ˳ö¸Ãº¯Êý¡£
Èç¹ûÒÑÑ¡Ôñһλ¿Í»§£¬Ôò showCustomer() º¯Êý»áÖ´ÐÐÒÔϲ½Ö裺
- ´´½¨ XMLHttpRequest ¶ÔÏó
- ´´½¨ÔÚ·þÎñÆ÷ÏìÓ¦¾ÍÐ÷ʱִÐеĺ¯Êý
- Ïò·þÎñÆ÷ÉϵÄÎļþ·¢ËÍÇëÇó
- Çë×¢ÒâÌí¼Óµ½ URL Ä©¶ËµÄ²ÎÊý£¨q£©£¨°üº¬ÏÂÀÁбíµÄÄÚÈÝ£©
ASP Îļþ
ÉÏÃæÕâ¶Î JavaScript µ÷ÓõķþÎñÆ÷Ò³ÃæÊÇÃûΪ "getcustomer.asp" µÄ ASP Îļþ¡£
"getcustomer.asp" ÖеÄÔ´´úÂë»áÔËÐÐÒ»´ÎÕë¶ÔÊý¾Ý¿âµÄ²éѯ£¬È»ºóÔÚ HTML ±í¸ñÖзµ»Ø½á¹û£º
<%
response.expires=-1
sql="SELECT * FROM CUSTOMERS WHERE CUSTOMERID="
sql=sql & "'" & request.querystring("q") & "'"
set conn=Server.CreateObject("ADODB.Connection")
conn.Provider="Microsoft.Jet.OLEDB.4.0"
conn.Open(Server.Mappath("/db/northwind.mdb"))
set rs=Server.CreateObject("ADODB.recordset")
rs.Open sql,conn
response.write("<table>")
do until rs.EOF
for each x in rs.Fields
response.write("<tr><td><b>" & x.name & "</b></td>")
response.write("<td>" & x.value & "</td></tr>")
next
rs.MoveNext
loop
response.write("</table>")
%>