课程表

PHP 基础教程

PHP 表单

PHP 高级教程

PHP 数据库

PHP XML

PHP 和 AJAX

PHP 参考手册

PHP 案例

工具箱
速查手册

AJAX XML

当前位置:免费教程 » 程序设计 » PHP

AJAX 可与 XML 文件进行交互式通信。

AJAX XML 实例

在下面的 AJAX 实例中,我们将演示网页如何使用 AJAX 技术从 XML 文件中读取信息。

在下面的下列列表中选择一个 CD

TITLE:
ARTIST:
COUNTRY:
COMPANY:
PRICE:
YEAR:

由于本站过滤了空格,因此显示是非法的,但是如果在正常的设置下,会显示这些CD的信息。

本例包括三张页面:

  • 一个简单 HTML 表单
  • 一个 XML 文件
  • 一个 JavaScript 文件
  • 一张 PHP 页面

HTML 表单

上面的例子包含了一张简单的 HTML 表单,以及指向 JavaScript 的链接:

  1. <html>
  2. <head>
  3. <script src="selectcd.js"></script>
  4. </head>
  5.  
  6. <body>
  7.  
  8. <form>
  9. Select a CD:
  10. <select name="cds" onchange="showCD(this.value)">
  11. <option value="Bob Dylan">Bob Dylan</option>
  12. <option value="Bee Gees">Bee Gees</option>
  13. <option value="Cat Stevens">Cat Stevens</option>
  14. </select>
  15. </form>
  16.  
  17. <p>
  18. <div id="txtHint"><b>CD info will be listed here.</b></div>
  19. </p>
  20.  
  21. </body>
  22. </html>

例子解释:

正如您看到的,它仅仅是一张简单的 HTML 表单,其中带有名为 "cds" 的下拉列表。

表单下面的段落包含了一个名为 "txtHint" 的 div。这个 div 用作从 web 服务器检索到的数据的占位符。

当用户选择数据时,会执行名为 "showCD" 的函数。这个函数的执行是由 "onchange" 事件触发的。

换句话说,每当用户改变了下拉列表中的值,就会调用 showCD 函数。

XML 文件

XML 文件是 "cd_catalog.xml"。该文件中包含了有关 CD 收藏的数据。

JavaScript

这是存储在 "selectcd.js" 文件中的 JavaScript 代码:

  1. var xmlHttp
  2.  
  3. function showCD(str)
  4. {
  5. xmlHttp=GetXmlHttpObject()
  6. if (xmlHttp==null)
  7. {
  8. alert ("Browser does not support HTTP Request")
  9. return
  10. }
  11. var url="getcd.php"
  12. url=url+"?q="+str
  13. url=url+"&sid="+Math.random()
  14. xmlHttp.onreadystatechange=stateChanged
  15. xmlHttp.open("GET",url,true)
  16. xmlHttp.send(null)
  17. }
  18.  
  19. function stateChanged()
  20. {
  21. if (xmlHttp.readyState==4 || xmlHttp.readyState=="complete")
  22. {
  23. document.getElementById("txtHint").innerHTML=xmlHttp.responseText
  24. }
  25. }
  26.  
  27. function GetXmlHttpObject()
  28. {
  29. var xmlHttp=null;
  30.  
  31. try
  32. {
  33. // Firefox, Opera 8.0+, Safari
  34. xmlHttp=new XMLHttpRequest();
  35. }
  36. catch (e)
  37. {
  38. // Internet Explorer
  39. try
  40. {
  41. xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
  42. }
  43. catch (e)
  44. {
  45. xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
  46. }
  47. }
  48. return xmlHttp;
  49. }

例子解释:

stateChanged() 和 GetXmlHttpObject 函数与上一节中的相同,您可以参阅上一页中的相关解释。

showCD() 函数

假如选择了下拉列表中的某个项目,则函数执行:

  1. 调用 GetXmlHttpObject 函数来创建 XMLHTTP 对象
  2. 定义发送到服务器的 URL(文件名)
  3. 向 URL 添加带有下拉列表内容的参数 (q)
  4. 添加一个随机数,以防服务器使用缓存的文件
  5. 当触发事件时调用 stateChanged
  6. 通过给定的 URL 打开 XMLHTTP 对象
  7. 向服务器发送 HTTP 请求

PHP 页面

这个被 JavaScript 调用的服务器页面,是一个名为 "getcd.php" 的简单 PHP 文件。

这张页面是用 PHP 编写的,使用 XML DOM 来加载 XML 文档 "cd_catalog.xml"。

代码运行针对 XML 文件的查询,并以 HTML 返回结果:

  1. <?php
  2. $q=$_GET["q"];
  3.  
  4. $xmlDoc = new DOMDocument();
  5. $xmlDoc->load("cd_catalog.xml");
  6.  
  7. $x=$xmlDoc->getElementsByTagName('ARTIST');
  8.  
  9. for ($i=0; $i<=$x->length-1; $i++)
  10. {
  11. //Process only element nodes
  12. if ($x->item($i)->nodeType==1)
  13. {
  14. if ($x->item($i)->childNodes->item(0)->nodeValue == $q)
  15. {
  16. $y=($x->item($i)->parentNode);
  17. }
  18. }
  19. }
  20.  
  21. $cd=($y->childNodes);
  22.  
  23. for ($i=0;$i<$cd->length;$i++)
  24. {
  25. //Process only element nodes
  26. if ($cd->item($i)->nodeType==1)
  27. {
  28. echo($cd->item($i)->nodeName);
  29. echo(": ");
  30. echo($cd->item($i)->childNodes->item(0)->nodeValue);
  31. echo("<br />");
  32. }
  33. }
  34. ?>

例子解释

当请求从 JavaScript 发送到 PHP 页面时,发生:

  1. PHP 创建 "cd_catalog.xml" 文件的 XML DOM 对象
  2. 循环所有 "artist" 元素 (nodetypes = 1),查找与 JavaScript 所传数据向匹配的名字
  3. 找到 CD 包含的正确 artist
  4. 输出 album 的信息,并发送到 "txtHint" 占位符
转载本站内容时,请务必注明来自W3xue,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号