PHP and AJAX XML Example

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

Ami ce mai tsawon da kuma likita AJAX XML

A cikin aikin AJAX na kwananin, a za a fi gani da hakan kuma yin amfani da aikin AJAX domin kiyasta bayanin daga fayilin XML.

Yan kwanan na kwananin da suka biya a cikin kwananin na kwananin:

Duba kuma CD na bayanin.

Ami ce mai tsawon da kuma likita tawọn yarjejeniya:

  • HTML form ce mai tsawon da kuma likita
  • XML da yarjejeniya
  • JavaScript da yarjejeniya
  • PHP da yarjejeniya

HTML form

Ami ce mai tsawon da ta da kuma likita HTML form ce da kuma yin haɗa da JavaScript:






Select a CD:

CD info will be listed here.

例子解释:

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

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

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

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

fiilen XML

fiilen XML a jiki ni "cd_catalog.xmlwannan takan "wannan takan "wannan a hanyar "selectcd.js" takan JavaScript a aiki".

JavaScript

ani wani a hanyar "selectcd.js" takan JavaScript a aiki

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() 函数

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

  1. 调用 GetXmlHttpObject 函数来创建 XMLHTTP 对象
  2. 定义发送到服务器的 URL(文件名)
  3. 向 URL 添加带有下拉列表内容的参数 (q)
  4. 添加一个随机数,以防服务器使用缓存的文件
  5. Yanda kaiwa da kuma stateChanged yana kaiwa idan mayar da halin
  6. Duba XMLHTTP object ta URL da a kai.
  7. Rannu HTTP samun kai daga server

PHP wuri

Wurin yana kaiwa da wani wuri da JavaScript ke kira, wanda shine fayilin PHP na 'getcd.php' na daidai.

Wurin yanar da wannan takarda shine da PHP ke kira, wanda ke amfani da XML DOM domin tsara dokoki XML:cd_catalog.xml"。

Koda run na bayanin XML fafin da, kuma a cewa HTML a cewa shiyya:

<?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. PHP إنشاء XML DOM Object للملف "cd_catalog.xml"
  2. تكرار جميع عناصر "artist" (nodetypes = 1)، البحث عن الأسماء التي تتطابق مع البيانات التي يتم إرسالها من JavaScript
  3. إيجاد CD يحتوي على الفنان الصحيح
  4. إخراج معلومات "album"并发رستها إلى "txtHint"