Пример XML в AJAX

AJAX можно использовать для интерактивного взаимодействия с XML-файлами.

Пример XML в AJAX

Ниже приведен пример того, как веб-страница может читать информацию из XML-файла с помощью AJAX:

Пример

Попробуйте сами

Объяснение примера

Когда пользователь нажимает кнопку "Получить информацию о CD", выполняется функция loadDoc().

Функция loadDoc() создает объект XMLHttpRequest, добавляет функцию, которая будет выполняться при готовности серверного ответа, и отправляет запрос на сервер.

После того как сервер готов к ответу, создайте таблицу HTML, извлеките узлы (элементы) из XML-файла и в конечном итоге обновите элемент "demo" таблицей HTML, заполненной данными XML:

LoadXMLDoc()

function loadDoc() {
  var xhttp = new XMLHttpRequest();
   xhttp.onreadystatechange = function() {
    if (this.readyState == 4 && this.status == 200) {
    myFunction(this);
     }
  };
  xhttp.open("GET", "music_list.xml", true);
  xhttp.send();
}
function myFunction(xml) {
  var i;
  var xmlDoc = xml.responseXML;
  var table="<tr><th>Артист</th><th>Трек</th></tr>";
  var x = xmlDoc.getElementsByTagName("TRACK");
  for (i = 0; i <x.length;  i++) { 
    table += "<tr><td>" +
    x[i].getElementsByTagName("ARTIST")[0].childNodes[0].nodeValue  +
    "</td><td>" +
    x[i].getElementsByTagName("TITLE")[0].childNodes[0].nodeValue  +
    "</td></tr>";
  }
   document.getElementById("demo").innerHTML = table;
} 

Файл XML

В предыдущем примере используется файл XML, подобный этому: "music_list.xml"。