PHP 완전 자율 학습 매뉴...login
PHP 완전 자율 학습 매뉴얼
작가:php.cn  업데이트 시간:2022-04-15 13:53:54

AJAX XML


PHP 예 - AJAX with XML


AJAX를 사용하여 XML 파일과 대화식으로 통신할 수 있습니다.


AJAX XML 예

다음 예는 웹 페이지가 AJAX를 통해 XML 파일에서 정보를 읽는 방법을 보여줍니다.


CD 정보는 여기에 나열됩니다...



예제 설명 - HTML 페이지

사용자가 위의 드롭다운 목록에서 CD를 선택하면 "showCD()"라는 함수가 실행됩니다. 이 함수는 "onchange" 이벤트에 의해 트리거됩니다:

<html>
<head>
<script>
function showCD(str)
{
      if (str=="")
      {
              document.getElementById("txtHint").innerHTML="";
              return;
      } 
      if (window.XMLHttpRequest)
      {
             // IE7+, Firefox, Chrome, Opera, Safari 浏览器执行
             xmlhttp=new XMLHttpRequest();
      }
      else
      {
            // IE6, IE5 浏览器执行
            xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
      }
      xmlhttp.onreadystatechange=function()
      {
            if (xmlhttp.readyState==4 && xmlhttp.status==200)
            {
                 document.getElementById("txtHint").innerHTML=xmlhttp.responseText;
            }
      }
      xmlhttp.open("GET","getcd.php?q="+str,true);
      xmlhttp.send();
}
</script>
</head>
<body>
<form>
Select a CD:
<select name="cds" onchange="showCD(this.value)">
<option value="">Select a CD:</option>
<option value="Bob Dylan">Bob Dylan</option>
<option value="Bonnie Tyler">Bonnie Tyler</option>
<option value="Dolly Parton">Dolly Parton</option>
</select>
</form>
<div id="txtHint"><b>CD info will be listed here...</b></div>
</body>
</html>

showCD() 함수는 다음 단계를 수행합니다:

  • CD 선택 여부 확인

  • XMLHttpRequest 객체 생성

  • 서버 응답이 준비되면 실행되는 함수 생성

  • 서버의 파일에 요청 보내기

  • URL 끝에 추가된 매개변수(q)에 유의하세요( 드롭다운 목록)


PHP 파일

위에서 JavaScript를 통해 호출되는 서버 페이지는 "getcd.php"라는 이름의 PHP 파일입니다.

PHP 스크립트는 XML 문서 "cd_catalog.xml"을 로드하고 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++)
{
      // 处理元素节点
      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++)
{ 
      // 处理元素节点
      if ($cd->item($i)->nodeType==1)
      {
            echo("<b>" . $cd->item($i)->nodeName . ":</b> ");
            echo($cd->item($i)->childNodes->item(0)->nodeValue);
            echo("<br>");
      }
}
?>

CD 쿼리가 JavaScript에서 PHP 페이지로 전송되면 다음과 같은 일이 발생합니다.

  1. PHP는 XML DOM 개체를 생성합니다.

  2. 모든 <artist> 요소 찾기 JavaScript

  3. 에서 전달한 데이터와 일치하는 이름은 앨범 정보를 출력하고 "txtHint" 자리 표시자

<🎜를 보냅니다. >

추천 관련 동영상 튜토리얼: "AJAX 튜토리얼"http://www.php.cn/course/list/25.html