AJAX ASP/PHP

ajax asp/php 實(shí)例

ajax 用于創(chuàng)造動態(tài)性更強(qiáng)的應(yīng)用程序。

ajax asp/php 實(shí)例

下面的例子將為您演示當(dāng)用戶在輸入框中鍵入字符時,網(wǎng)頁如何與 web 服務(wù)器進(jìn)行通信: 請?jiān)谙旅娴妮斎肟蛑墟I入字母(a - z):

 function showhint(str)
{
  var xmlhttp;
  if (str.length==0)
  { 
    document.getelementbyid("txthint").innerhtml="";
    return;
  }
  if (window.xmlhttprequest)
  {
    // ie7+, firefox, chrome, opera, safari 瀏覽器執(zhí)行代碼
    xmlhttp=new xmlhttprequest();
  }
  else
  {
    // ie6, ie5 瀏覽器執(zhí)行代碼
    xmlhttp=new activexobject("microsoft.xmlhttp");
  }
  xmlhttp.onreadystatechange=function()
  {
    if (xmlhttp.readystate==4 && xmlhttp.status==200)
    {
      document.getelementbyid("txthint").innerhtml=xmlhttp.responsetext;
    }
  }
  xmlhttp.open("get","/try/ajax/gethint.php?q="+str,true);
  xmlhttp.send();
}

實(shí)例

在輸入框中嘗試輸入字母 a:

輸入姓名:

提示信息:




實(shí)例解析 - showhint() 函數(shù)

當(dāng)用戶在上面的輸入框中鍵入字符時,會執(zhí)行函數(shù) "showhint()" 。該函數(shù)由 "onkeyup" 事件觸發(fā):

function showhint(str) { var xmlhttp; if (str.length==0) { document.getelementbyid("txthint").innerhtml=""; return; } if (window.xmlhttprequest) { // ie7+, firefox, chrome, opera, safari 瀏覽器執(zhí)行代碼 xmlhttp=new xmlhttprequest(); } else { // ie6, ie5 瀏覽器執(zhí)行代碼 xmlhttp=new activexobject("microsoft.xmlhttp"); } xmlhttp.onreadystatechange=function() { if (xmlhttp.readystate==4 && xmlhttp.status==200) { document.getelementbyid("txthint").innerhtml=xmlhttp.responsetext; } } xmlhttp.open("get","/try/ajax/gethint.php?q="+str,true); xmlhttp.send();}

源代碼解析:

如果輸入框?yàn)榭?str.length==0,則該函數(shù)清空 txthint 占位符的內(nèi)容,并退出函數(shù)。

如果輸入框不為空,showhint() 函數(shù)執(zhí)行以下任務(wù):

  • 創(chuàng)建 xmlhttprequest 對象
  • 當(dāng)服務(wù)器響應(yīng)就緒時執(zhí)行函數(shù)
  • 把請求發(fā)送到服務(wù)器上的文件
  • 請注意我們向 url 添加了一個參數(shù) q (帶有輸入框的內(nèi)容)

ajax 服務(wù)器頁面 - asp 和 php

以上實(shí)例 javascript 調(diào)用的服務(wù)器頁面是 php 文件,名為 gethint.php。

下面,我們創(chuàng)建了兩個版本的服務(wù)器文件,一個用 asp 編寫,另一個用 php 編寫。

asp 文件

"gethint.asp" 中的源代碼會檢查一個名字?jǐn)?shù)組,然后向?yàn)g覽器返回相應(yīng)的名字:

<%
response.expires=-1
dim a(30)
'fill up array with names
a(1)="anna"
a(2)="brittany"
a(3)="cinderella"
a(4)="diana"
a(5)="eva"
a(6)="fiona"
a(7)="gunda"
a(8)="hege"
a(9)="inga"
a(10)="johanna"
a(11)="kitty"
a(12)="linda"
a(13)="nina"
a(14)="ophelia"
a(15)="petunia"
a(16)="amanda"
a(17)="raquel"
a(18)="cindy"
a(19)="doris"
a(20)="eve"
a(21)="evita"
a(22)="sunniva"
a(23)="tove"
a(24)="unni"
a(25)="violet"
a(26)="liza"
a(27)="elizabeth"
a(28)="ellen"
a(29)="wenche"
a(30)="vicky"

'get the q parameter from url
q=ucase(request.querystring("q"))

'lookup all hints from array if length of q>0
if len(q)>0 then
  hint=""
  for i=1 to 30
    if q=ucase(mid(a(i),1,len(q))) then
      if hint="" then
        hint=a(i)
      else
        hint=hint & " , " & a(i)
      end if
    end if
  next
end if

'output "no suggestion" if no hint were found
'or output the correct values
if hint="" then
  response.write("no suggestion")
else
  response.write(hint)
end if
%>

php 文件

下面的代碼用 php 編寫,與上面的 asp 代碼作用是一樣的。

0
if (strlen($q) > 0)
{
  $hint="";
  for($i=0; $i                
相關(guān)文章
亚洲国产精品第一区二区,久久免费视频77,99V久久综合狠狠综合久久,国产免费久久九九免费视频