AJax技术

AJAX XML 实例

字号+ 作者:H5之家 来源:H5之家 2017-12-07 10:01 我要评论( )

AJAX XML 实例本例包括三张页面:一个简单 HTML 表单一个 XML 文件一个 JavaScript 文件一张 PHP 页面HTML 表单上面的例子包含了一张简单的 HTML 表单,以及指向

AJAX XML 实例

本例包括三张页面:

HTML 表单

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

<html> <head> <script src="selectcd.js"></script> </head> <body> <form>  Select a CD: <select name="cds" onchange="showCD(this.value)"> <option value="Bob Dylan">Bob Dylan</option> <option value="Bee Gees">Bee Gees</option> <option value="Cat Stevens">Cat Stevens</option> </select> </form> <p> <div id="txtHint"><b>CD info will be listed here.</b></div> </p> </body> </html>例子解释:

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

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

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

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

JavaScript

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

var xmlHttp function showCD(str) {  xmlHttp=GetXmlHttpObject() if (xmlHttp==null)  {  alert ("Browser does not support HTTP Request")  return  }  var url="getcd.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; }例子解释:

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

showCD() 函数

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

PHP 页面

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

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

<?php $q=$_GET["q"]; $xmlDoc = new DOMDocument(); $xmlDoc->load("cd_catalog.xml"); $x=$xmlDoc->getElementsByTagName('ARTIST'); for ($i=0; $i<=$x->length-1; $i++) { //Process only element nodes if ($x->item($i)->nodeType==1)   {   if ($x->item($i)->childNodes->item(0)->nodeValue == $q)     {      $y=($x->item($i)->parentNode);     }   } } $cd=($y->childNodes); for ($i=0;$i<$cd->length;$i++) {  //Process only element nodes if ($cd->item($i)->nodeType==1)   {    echo($cd->item($i)->nodeName);   echo(": ");   echo($cd->item($i)->childNodes->item(0)->nodeValue);   echo("<br />");   }  } ?>例子解释

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

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • PHP 和 AJAX 请求

    PHP 和 AJAX 请求

    2017-12-06 17:00

  • 获取网页 HTML 中 Title内容的代码

    获取网页 HTML 中 Title内容的代码

    2017-12-06 13:00

  • Web前端面试题:什么是 AJAX ?

    Web前端面试题:什么是 AJAX ?

    2017-11-25 14:40

  • Ajax技术与传统Web应用的比较

    Ajax技术与传统Web应用的比较

    2017-11-20 18:10

网友点评