初めてAJAXを使用しようとしていますが、難しい状況に陥っています。ここで要求コードは次のとおりです。AJAXがnullを返すXML
function requestData(j) {
var xmlhttp;
if (window.XMLHttpRequest) {
xmlhttp=new XMLHttpRequest();
}
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState==4 && xmlhttp.status==200) {
xml = xmlhttp.responseXML;
post = "";
title = "";
postdata = xml.getElementsByTagName("post");
titledata = xml.getElementsByTagName("title");
datedata = xml.getElementsByTagName("date");
timedata = xml.getElementsByTagName("time");
document.getElementById("post").value = postdata[0].childNodes[0].nodeValue;
document.getElementById("heading").value = titledata[0].childNodes[0].nodeValue;
document.getElementById("date").value = datedata[0].childNodes[0].nodeValue;
document.getElementById("time").value = timedata[0].childNodes[0].nodeValue;
document.getElementById("id").value = j;
document.getElementById("update").value = "true";
}
};
xmlhttp.open("POST","../script/getnewsdata.php",true);
xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
xmlhttp.send("ID=" + j);
return false;
}
Firebugのは、ラインPOSTDATA = xml.getElementsByTagName(「ポスト」)の「XMLがnullである」ことを私に語っています。つまり、xmlhttp.responseXMLはnullです。
これは、サーバー側のスクリプトです:
<?php
$db = mysql_connect("wadafw","awfawf","awfsgv");
if(!$db)
{
die("Could not connect: " . mysql_error());
}
mysql_select_db("afggbare", $db);
$updata = mysql_query('SELECT * FROM News WHERE NewsID='.$_POST['ID']);
$blog = mysql_fetch_array($updata);
$post = $blog['Content'];
$regex = Array('/<br />/', '/<(\/?)(b|i|u)>/', '/<a href="(http://[www.]?\w+)">(\w+)<\/a>/', '/<div class="media"><iframe title="YouTube video player" width="425" height="265" src="http://www.youtube.com/embed/(\w+)hd=1" frameborder="0" allowfullscreen></iframe></div>/', '/<div class="media"><img width="425" src="(http://[www.]?[\w+])" /></div>/');
$regReplace = Array('\r\n', '[$1$2]', '[link=$1]$2[/link]', '[youtube]http://www.youtube.com/watch?v=$1[/youtube]',
'[img]$1[/img]');
$post = preg_replace($regex, $regReplace, $post);
echo '<newsItem>
<title>'.$blog['Heading'].'</title>
<post>'.$post.'</post>
<date>'.$blog['time'].'</date>
<time>'.$blog['time'].'</time>
</newsItem>';
?>
正規表現は、おそらく悪いです...しかし、それは今重要ではありません。
が...これに変更され、現在取得エラー "機能が定義されていません": オーケーfunction requestData(j) {
$.ajax("../script/getnewsdata.php", {
data: {ID: j},
type: "POST",
dataType: "xml",
success: function(data, status, jqXHR){
var xml = jqXHR.responseXML;
postdata = xml.getElementsByTagName("post");
titledata = xml.getElementsByTagName("title");
datedata = xml.getElementsByTagName("date");
timedata = xml.getElementsByTagName("time");
document.getElementById("post").value = postdata[0].childNodes[0].nodeValue;
document.getElementById("heading").value = titledata[0].childNodes[0].nodeValue;
document.getElementById("date").value = datedata[0].childNodes[0].nodeValue;
document.getElementById("time").value = timedata[0].childNodes[0].nodeValue;
document.getElementById("id").value = j;
document.getElementById("update").value = "true";
}
}
}
は、その問題を発見しました。それはちょうどタイプミスです... $ .ajax()パラメータの括弧を閉じていませんでした。今私はエラーを取得していません。しかし、それだけで何もしません...
の ''? –
申し訳ありませんが、忘れました。それは今だが、私は同じ問題を抱えている。 – Luke