我正在使用 javascript 和 php 来获取自动建议。
<div>
<div>
University Name:<input type="text" size="20" name="uni" value="" id="uniString" onkeyup="lookup(this.value);" onblur="fill();">
</div>
<div class="suggestionsBox" id="suggestions" style="display: none;">
<div class="suggestionList" id="autoSuggestionsList">
</div>
</div>
</div>
当用户键入名称时,我会显示结果并使用填充函数来获取值。一切正常。但是有什么方法可以使用“thisValue”(即所选大学)来打印下拉列表?我想打印所选大学的课程,所以我写了这段代码:
function lookup(uniString) {
if (uniString.length == 0) {
// Make the suggestions box invisible
$('#suggestions').hide();
} else {
$.post("autosuggestions.php", {
universityString: "" + uniString + ""
}, function(data) {
if (data.length > 0) {
$('#suggestions').show();
$('#autoSuggestionsList').html(data);
}
});
}
} // lookup
function fill(thisValue) {
if (thisValue) {
$('#uniString').val(thisValue);
var strURL = "findCourse.php?uniString=" + thisValue;
var req = getXMLHTTP();
if (req) {
req.onreadystatechange = function() {
if (req.readyState == 4) {
// only if "OK"
if (req.status == 200) {
document.getElementById('coursediv').innerHTML = req.responseText;
} else {
alert("There was a problem while using XMLHTTP:\n" + req.statusText);
}
}
}
req.open("GET", strURL, true);
req.send(null);
}
} else {
setTimeout("$('#suggestions').hide();", 200);
}
}
findCourse.php: $uni = $_POST['uniString'];
$query = mysql_query("SELECT .... FROM .... WHERE university.uni_name='$uniString' AND .......");
if ($query) {
....
}`enter code here`
不幸的是,它不起作用。我用'document.write()'对其进行了测试。thisValue 打印了什么,它打印了大学名称(这就是我想要的)。但是当我将值传递给 php 文件 (getCourse.php) 时,结果值为 null。
任何人都可以帮助我吗?我很确定我的问题很愚蠢,对此我很抱歉,我在 javascript 方面不是很好。