html5中文学习网

您的位置: 首页 > 网络编程 > ASP编程 » 正文

PHP和AJAX请求_ASP教程_编程技术

[ ] 已经帮助:人解决问题
在下面的 AJAX 例子中,我们将演示当用户向 web 表单中输入数据时,网页如何与在线的 web 服务器进行通信。

在下面的 AJAX 例子中,我们将演示当用户向 web 表单中输入数据时,网页如何与在线的 web 服务器进行通信。RuYHTML5中文学习网 - HTML5先行者学习网

在下面的文本框中输入一个名字(测试说明:该实例功能未实现)RuYHTML5中文学习网 - HTML5先行者学习网

First Name: 
Suggestions:RuYHTML5中文学习网 - HTML5先行者学习网

这个例子包括三张页面:RuYHTML5中文学习网 - HTML5先行者学习网

a simple HTML form
a JavaScript
a PHP page
HTML 表单RuYHTML5中文学习网 - HTML5先行者学习网

这是 HTML 表单。它包含一个简单的 HTML 表单和指向 JavaScript 的链接:RuYHTML5中文学习网 - HTML5先行者学习网

<html>
<head>
<script src="clienthint.js"></script>
</head>
<body>
<form>
First Name:
<input type="text" id="txt1"
onkeyup="showHint(this.value)">
</form>
<p>Suggestions: <span id="txtHint"></span></p>
</body>
</html>RuYHTML5中文学习网 - HTML5先行者学习网

例子解释 - HTML 表单RuYHTML5中文学习网 - HTML5先行者学习网

正如您看到的,上面的 HTML 页面含有一个简单的 HTML 表单,其中带有一个名为 "txt1" 的输入字段。RuYHTML5中文学习网 - HTML5先行者学习网

该表单是这样工作的:RuYHTML5中文学习网 - HTML5先行者学习网

当用户在输入域中按下并松开按键时,会触发一个事件RuYHTML5中文学习网 - HTML5先行者学习网

当该事件被触发时,执行名为 showHint() 的函数RuYHTML5中文学习网 - HTML5先行者学习网

表单的下面是一个名为 "txtHint" 的 <span>。它用作 showHint() 函数所返回数据的占位符。RuYHTML5中文学习网 - HTML5先行者学习网

JavaScriptRuYHTML5中文学习网 - HTML5先行者学习网

JavaScript 代码存储在 "clienthint.js" 文件中,它被链接到 HTML 文档:RuYHTML5中文学习网 - HTML5先行者学习网

var xmlHttp
function showHint(str)
{
if (str.length==0)
  {
  document.getElementById("txtHint").innerHTML=""
  return
  }
xmlHttp=GetXmlHttpObject()
if (xmlHttp==null)
  {
  alert ("Browser does not support HTTP Request")
  return
  }
var url="gethint.php"
url=url+"?q="+str
url=url+"&sid="+Math.random()
xmlHttp.onreadystatechange=stateChanged
xmlHttp.open("GET",url,true)
xmlHttp.send(null)
}
function stateChanged()
{
if (xmlHttp.readyState==4 xmlHttp.readyState=="complete")
 {
 document.getElementById("txtHint").innerHTML=xmlHttp.responseText
 }
}
function GetXmlHttpObject()
{
var xmlHttp=null;
try
 {
 // Firefox, Opera 8.0+, Safari
 xmlHttp=new XMLHttpRequest();
 }
catch (e)
 {
 // Internet Explorer
 try
  {
  xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
  }
 catch (e)
  {
  xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
 }
return xmlHttp;
}RuYHTML5中文学习网 - HTML5先行者学习网

例子解释:RuYHTML5中文学习网 - HTML5先行者学习网

showHint() 函数RuYHTML5中文学习网 - HTML5先行者学习网

每当在输入域中输入一个字符,该函数就会被执行一次。RuYHTML5中文学习网 - HTML5先行者学习网

如果文本框中有内容 (str.length > 0),该函数这样执行:RuYHTML5中文学习网 - HTML5先行者学习网

定义要发送到服务器的 URL(文件名)
把带有输入域内容的参数 (q) 添加到这个 URL
添加一个随机数,以防服务器使用缓存文件
调用 GetXmlHttpObject 函数来创建 XMLHTTP 对象,并在事件被触发时告知该对象执行名为 stateChanged 的函数
用给定的 URL 来打开打开这个 XMLHTTP 对象
向服务器发送 HTTP 请求RuYHTML5中文学习网 - HTML5先行者学习网

如果输入域为空,则函数简单地清空 txtHint 占位符的内容。RuYHTML5中文学习网 - HTML5先行者学习网

stateChanged() 函数RuYHTML5中文学习网 - HTML5先行者学习网

每当 XMLHTTP 对象的状态发生改变,则执行该函数。RuYHTML5中文学习网 - HTML5先行者学习网

在状态变成 4 (或 "complete")时,用响应文本填充 txtHint 占位符 txtHint 的内容。RuYHTML5中文学习网 - HTML5先行者学习网

GetXmlHttpObject() 函数RuYHTML5中文学习网 - HTML5先行者学习网

AJAX 应用程序只能运行在完整支持 XML 的 web 浏览器中。RuYHTML5中文学习网 - HTML5先行者学习网

上面的代码调用了名为 GetXmlHttpObject() 的函数。RuYHTML5中文学习网 - HTML5先行者学习网

该函数的作用是解决为不同浏览器创建不同 XMLHTTP 对象的问题。RuYHTML5中文学习网 - HTML5先行者学习网

这一点在上一节中已经解释过了。RuYHTML5中文学习网 - HTML5先行者学习网

PHP 页面RuYHTML5中文学习网 - HTML5先行者学习网

被 JavaScript 代码调用的服务器页面是一个名为 "gethint.php" 的简单服务器页面。RuYHTML5中文学习网 - HTML5先行者学习网

"gethint.php" 中的代码会检查名字数组,然后向客户端返回对应的名字:RuYHTML5中文学习网 - HTML5先行者学习网

<?php
// Fill up array with names
$a[]="Anna";
$a[]="Brittany";
$a[]="Cinderella";
$a[]="Diana";
$a[]="Eva";
$a[]="Fiona";
$a[]="Gunda";
$a[]="Hege";
$a[]="Inga";
$a[]="Johanna";
$a[]="Kitty";
$a[]="Linda";
$a[]="Nina";
$a[]="Ophelia";
$a[]="Petunia";
$a[]="Amanda";
$a[]="Raquel";
$a[]="Cindy";
$a[]="Doris";
$a[]="Eve";
$a[]="Evita";
$a[]="Sunniva";
$a[]="Tove";
$a[]="Unni";
$a[]="Violet";
$a[]="Liza";
$a[]="Elizabeth";
$a[]="Ellen";
$a[]="Wenche";
$a[]="Vicky";
//get the q parameter from URL
$q=$_GET["q"];
//lookup all hints from array if length of q>0
if (strlen($q) > 0)
{
$hint="";
for($i=0; $i<count($a); $i++)
  {
  if (strtolower($q)==strtolower(substr($a[$i],0,strlen($q))))
    {
    if ($hint=="")
      {
      $hint=$a[$i];
      }
    else
      {
      $hint=$hint." , ".$a[$i];
      }
    }
  }
}
//Set output to "no suggestion" if no hint were found
//or to the correct values
if ($hint == "")
{
$response="no suggestion";
}
else
{
$response=$hint;
}
//output the response
echo $response;
?>RuYHTML5中文学习网 - HTML5先行者学习网

如果存在从 JavaScript 送来的文本 (strlen($q) > 0),则:RuYHTML5中文学习网 - HTML5先行者学习网

找到与 JavaScript 所传送的字符相匹配的名字
如果找到多个名字,把所有名字包含在 response 字符串中
如果没有找到匹配的名字,把 response 设置为 "no suggestion"
如果找到一个或多个名字,把 response 设置为这些名字
把 response 发送到 "txtHint" 占位符
 RuYHTML5中文学习网 - HTML5先行者学习网

RuYHTML5中文学习网 - HTML5先行者学习网
RuYHTML5中文学习网 - HTML5先行者学习网
(责任编辑:)
收藏文章
表情删除后不可恢复,是否删除
取消
确定
图片正在上传,请稍后...
评论内容为空!
还没有评论,快来抢沙发吧!
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助