Tukio wa Hatua wa AJAX kwa PHP
- 上一页 XMLHttpRequest
- 下一页 AJAX XML
AJAX 请求
在下面的 AJAX 例子中,我们将演示当用户向 web 表单中输入数据时,网页如何与在线的 web 服务器进行通信。
在下面的文本框中输入名字:
Suggestions:
这个例子包括三张页面:
- 一个简单的 HTML 表单
- 一段 JavaScript
- 一张 PHP 页面
HTML 表单
这是 HTML 表单。它包含一个简单的 HTML 表单和指向 JavaScript 的链接:
<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>
例子解释 - HTML 表单
正如您看到的,上面的 HTML 页面含有一个简单的 HTML 表单,其中带有一个名为 "txt1" 的输入字段。
该表单是这样工作的:
- 当用户在输入域中按下并松开按键时,会触发一个事件
- 当该事件被触发时,执行名为 showHint() 的函数
- 表单的下面是一个名为 "txtHint" 的 <span>。它用作 showHint() 函数所返回数据的占位符。
JavaScript
JavaScript 代码存储在 "clienthint.js" 文件中,它被链接到 HTML 文档:
var xmlHttp function showHint(str) { if (str.length==0) { document.getElementById("txtHint").innerHTML="" return } xmlHttp=GetXmlHttpObject() if (xmlHttp==null) { alert ("Mkono wa kifungu haitumie kipindi cha HTTP") 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; }
Mafanikio ya mbinu:
Funzi ya showHint()
Kila mara inayotumiwa heri kwenye eneo la input, programu hii inatumiwa mara moja kwa mara
Kama eneo la input linahusiana na maelezo (str.length > 0), programu hii inafanya kama iliyochukuliwa:
- Kuwezaa URL inayotumika kusaidia msaidia (jina la faili)
- Kuweka uamuzi wa eneo la input (q) katika URL hii
- Kuweka namba yasiyopendekeza, ili kuzingatia kwamba msaidia haitumie faili ya hifadhi
- Tumia kifaa cha GetXmlHttpObject kuanzisha XMLHTTP object, na kuwahakikisha kwamba kama tukio linaingizwa kusema kwamba kifaa cha kusema kinafunzi cha stateChanged
- Kuweka URL inayotumika kuuwa XMLHTTP object hii
- Kuandika kipindi cha HTTP kwa msaidia
如果输入域为空,则函数简单地清空 txtHint 占位符的内容。
stateChanged() 函数
每当 XMLHTTP 对象的状态发生改变,则执行该函数。
在状态变成 4 (或 "complete")时,用响应文本填充 txtHint 占位符 txtHint 的内容。
GetXmlHttpObject() 函数
AJAX 应用程序只能运行在完整支持 XML 的 web 浏览器中。
上面的代码调用了名为 GetXmlHttpObject() 的函数。
该函数的作用是解决为不同浏览器创建不同 XMLHTTP 对象的问题。
Hii ilikuwa ilivyoonyeshwa katika sehemu iliyopita.
Maktaba ya PHP
Maktaba ya msingi inayotumika na mifano ya JavaScript ni maktaba yenye jina "gethint.php" yenye msingi wa msingi wa kijifunzea.
"gethint.php" ina mifano inayotaka kichwa cha visano cha jina, kisha inatuma kwa kundi kwa jina:
<?php //kufaa kipende kwa visano vya jina $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"; //kufaa kiparamu cha q kutoka URL $q=$_GET["q"]; //kufaa kipende kwa visano vya array ikiwa ukubwa wa q kina msingi if (strlen($q) > 0) { $hint=""; for($i=0; $i
如果存在从 JavaScript 送来的文本 (strlen($q) > 0),则:
- 找到与 JavaScript 所传送的字符相匹配的名字
- 如果找到多个名字,把所有名字包含在 response 字符串中
- 如果没有找到匹配的名字,把 response 设置为 "no suggestion"
- 如果找到一个或多个名字,把 response 设置为这些名字
- 把 response 发送到 "txtHint" 占位符
- 上一页 XMLHttpRequest
- 下一页 AJAX XML