创建自定义XML,然后通过AJAX获取

时间:2011-11-22 13:47:39

标签: php javascript html xml ajax

出于某种原因,我在firebug中继续得到XMLDoc为null。我想也许我的程序没有解析我想要生成的XML(这意味着我可能没有正确地执行它。)

注意:我不想在这里使用JQUERY!

这是我应该生成XML代码的代码:

<?php
$con = mysql_connect("localhost", "root", "");
if (!$con)
{
    die('Could not connect: ' . mysql_error());
}
mysql_select_db("generic");
$rescult = mysql_query("SELECT * FROM culture order by cult_id");
if (!$rescult) {
    die('Invalid query: ' . mysql());
}
$row = mysql_fetch_row($rescult);
ECHO "<item>";
ECHO "<item1>" . $row[0] . "</item1>" . "<br />";
ECHO "<item2>" . $row[1] . "</item2>" . "<br />";
ECHO "</item>";
?>

这是我的代码,应该解析它:

<html>
<header>
<script type="text/javascript">

if (window.XMLHttpRequest)
{   // Code for IE7+, Firefox, Chrome, Opera, Safari
    xmlhttp = new XMLHttpRequest();
}
else
{   
    // Code for IE6, IE5
    xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","testitout2.php",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;

document.getElementById("item1").value =
xmlDoc.getElementsByTagName("item1")[0].childNodes[0].nodeValue;

document.getElementById("item2").value =
xmlDoc.getElementsByTagName("item2")[0].childNodes[0].nodeValue;

</script>
</header>
    <body>
        <input type="text" id="item1">
        <input type="text" id="item2">
    </body>
</html>

2 个答案:

答案 0 :(得分:1)

编辑:我没有注意到async标志。猜猜我的回答是无关紧要的。

您尝试在加载XML之前访问它。 将属性onreadystatechange设置为xmlhttp

 xmlhttp.onreadystatechange = onStateChange;

 function onStateChange() {
    if (xmlhttp.readyState != 4) return; //4 means doc is ready
    var xmlDoc = xmlhttp.responseXML;
 }

答案 1 :(得分:1)

您使用的是错误的HTML代码:<header>...</header>

尝试将其替换为<head>...</head>,否则浏览器可能会跳过您的脚本。