【发布时间】:2017-06-04 08:42:24
【问题描述】:
2017 年 1 月 19 日更新 - 问题已解决 - 在 get.php 文件中的 get 请求中删除了“intval”,值 q 现在正在捕获正确的数据。
我想要达到的目标可以总结为两点:
1.) 根据 MySql 表动态填充的下拉框
2.) 根据下拉菜单中选择的内容,下面的文本字段将通过 SQL 查询显示相应的 ID。
我一直在尝试关注 W3Schools guide 并相应地对其进行修改以满足我的需求,但我遇到了困难。
这是我目前拥有的:
PHP -
<?php
mysql_connect('localhost', 'root', '');
mysql_select_db('core_log');
$sql = "SELECT local_authority FROM ons_code_tbl";
$result = mysql_query($sql);
echo "<tr>";
echo "<td> Local Authority: </td>";
echo "<td>";
echo "<select name='local_authority'onchange='showLocal_authority(this.value)'>";
echo '<option value=""></option>';
while ($row = mysql_fetch_array($result)) {
echo "<option value='" . $row['local_authority'] . "'>" . $row['local_authority'] . "</option>";
}
echo "</select>";
echo "</td>";
echo "</tr>";
?>
脚本 -
<script>
function showLocal_authority(str) {
if (str == "") {
document.getElementById("txtHint").innerHTML = "";
return;
} else {
if (window.XMLHttpRequest) {
// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp = new XMLHttpRequest();
} else {
// code for IE6, IE5
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
document.getElementById("txtHint").innerHTML = this.responseText;
}
};
xmlhttp.open("GET","get.php?q="+str,true);
xmlhttp.send();
}
}
</script>
get.php -
<?php
$q = intval($_GET['q']);
$con = mysqli_connect('localhost','root','','core_log');
if (!$con) {
die('Could not connect: ' . mysqli_error($con));
}
mysqli_select_db($con,"ons_code_tbl");
$sql="SELECT ons_code FROM ons_code_tbl WHERE local_authority = '".$q."'";
$result = mysqli_query($con,$sql);
$row = mysqli_fetch_array($result);
$name = $row['ons_code'];
echo "<td>" . $q . "</td>";
mysqli_close($con);
?>
我做了一个测试,只是简单地回显了值 q 以查看它的输出,它应该是他们在下拉列表中选择的任何值,而不是显示 0?
在下面的屏幕截图中,它应该显示“Amber Valley”以及从 MySQL 表中提取的正确 ONS 代码。
如果有人能告诉我为什么值 q 不存储例如“Amber Valley”,那就太好了,谢谢!
【问题讨论】:
-
请给您的问题一个相关的标题。另请注意,W3Schools 与 W3C 完全无关,他们的建议通常已经过时,在某些情况下完全不正确。
-
您正在将 ajax 中的字符串发送到脚本 php,但第一行在此字符串上创建一个 intval,返回 0:php.net/manual/fr/function.intval.php
-
$q = intval($_GET['q']);的字符串将为 0 -
@Yoleth 就是这样,删除 intval 并使用 $_GET 只解决了我的问题!谢谢!
-
@FelippeDuarte 谢谢!删除 intval 解决了这个问题!