私はajaxを使用してmysqlデータベースでキーワード検索を使用しています。結果が表示されたら、onclick関数を使用してオプションをhrefとして表示したいのですが、検索は正常に機能しますが、いずれかのオプションをクリックすると、参照エラーが発生します。私のfirebug、これはコードです:index.php
<html>
<body>
<style>
#displayDiv {
background-color: #ffeeaa;
width: 200;
}
</style>
<script type="text/javascript">
function aca(esto) {
var esta = esto;
alert(esta);
}
</script>
<script type="text/javascript">
function ajaxFunction(str) {
var httpxml;
try {
// Firefox, Opera 8.0+, Safari
httpxml = new XMLHttpRequest();
} catch (e) {
// Internet Explorer
try {
httpxml = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
try {
httpxml = new ActiveXObject("Microsoft.XMLHTTP");
} catch (e) {
alert("Your browser does not support AJAX!");
return false;
}
}
}
function stateChanged() {
if (httpxml.readyState == 4) {
document.getElementById("displayDiv").innerHTML = httpxml.responseText;
}
}
var url = "search.php";
url = url + "?txt=" + str;
url = url + "&sid=" + Math.random();
httpxml.onreadystatechange = stateChanged;
httpxml.open("GET", url, true);
httpxml.send(null);
}
</script>
</head>
<body>
<form name="myForm">
<input type="text" onkeyup="ajaxFunction(this.value);" name="username"
/>
<div id="displayDiv"></div>
</form>
</body>
そしてこれはsearch.phpです
<?php
include ("dbinfo.php");
$in = $_GET['txt'];
$msg = "";
if (strlen($in) > 0 and strlen($in) < 20) {
$t = mysql_query("select RubroId, RubroDisp from rubros where KeyWords like '$in%'");
while ($nt = mysql_fetch_array($t)) {
$valor = $nt[RubroDisp];
$valorCodificado = str_replace(" ", "_", $valor);
echo "<a href='#' onclick='aca($valorCodificado);'>$valor</a><br />";
}
}
?>
このURLで作業ページを見ることができます
解決方法を教えてください。または私が間違っていることは何ですか?
ありがとう