php - 我们如何使用数据库动态更改一些下拉列表?

标签 php javascript mysql dynamic drop-down-menu

尝试从 mysql 数据库动态更改下拉列表值。脚本似乎可以工作,但我不确定。数据库列为 id、columnA、columnB、columnC、columnD

在选择第二个下拉列表时,它会发出“hi Again”警报。

$(document).ready(
function() {
$(".columnA").change(
function() {
    var dataA=$(this).val();
    var dataString = 'columnA='+ dataA;
    $.ajax (    {
                    type: "POST",
                    url: "ajax_try.php",
                    data: dataString,
                    cache: false,
                    success: function(html)
                    {
                        $(".columnB").html(html);
                    }    
                }               
            );

            }
    );

$(".columnB").change(
function() {
    var dataB=$(this).val();
    var dataString = 'columnB='+ dataB;
    $.ajax (    {
                    type: "POST",
                    url: "ajax_try.php",
                    data: dataString,
                    cache: false,
                    success: function(html)
                    {
                        alert("hi.. again");
                        $(".columnC").html(html);
                    }    
                }               
            );

            }
    );

});

<?php
include('db.php');
if($_POST['columnA'])
{
$columnA = $_POST['columnA'];

$sql = mysql_query("SELECT id, columnB FROM try WHERE columnA = '$columnA' GROUP BY columnB");

//$sql = mysql_query("SELECT id, columnB FROM try columnB WHERE columnA = '$columnA'");

while($row = mysql_fetch_array($sql))
{
$id = $row['id'];
$columnB = $row['columnB'];
echo '<option value="'.$id.'">'.$columnB.'</option>';

}
}


if($_POST['columnB'])
{
$columnB = $_POST['columnB'];

$sql = mysql_query("SELECT id, columnC FROM try WHERE columnB = '$columnB' GROUP BY columnC");

while($row = mysql_fetch_array($sql))
{
$id = $row['id'];
$columnC = $row['columnC'];
echo '<option value="'.$id.'">'.$columnC.'</option>';

}
}

?>

好吧,我认为 html 代码更容易理解问题..

<html xmlns="http://www.w3.org/1999/xhtml">
....
<script type="text/javascript" src="http://ajax.googleapis.com/
ajax/libs/jquery/1.4.2/jquery.min.js"></script>
<script type="text/javascript">
.....
here is the script
...
</script>
</head>
<body>
<table width="100%" border="0" cellpadding="10">
  <tr>
    <td width="15%"><span style="font-size:20px;">columnA</span></td>
    <td><span >
        <select size="1" id="columnA" title="" name="columnA" class="columnA"  style="width:250px; height:40px; font-size:20px; padding: 5px;">
            <option value="0" selected="selected">Choose..</option>
        <?php
            include('db.php');
            $sql=mysql_query("SELECT columnA FROM try GROUP BY columnA");
            while($row = mysql_fetch_array($sql))
            {
            //$id = $row['id'];
            $dataA = $row['columnA'];
            echo '<option value="'.$dataA.'">'.$dataA.'</option>';
            } 
        ?>
        </select>
        </span>
    </td>
  </tr>
  <tr>
     <td width="15%"><span style="font-size:20px;">columnB</span></td>
    <td>
        <select size="1" id="columnB"  title="" name="columnB" class="columnB" style="width:250px; height:40px; font-size:20px; padding: 5px;">
            <option value="0" selected="selected">Choose..</option>
        </select>
    </td>
  </tr>
  <tr>
     <td width="15%"><span style="font-size:20px;">columnC</span></td>
    <td>
        <select size="1" id="columnC"  title="" name="columnC" class="columnC" style="width:250px; height:40px; font-size:20px; padding: 5px;">
            <option value="0" selected="selected">Choose..</option>
        </select>
    </td>
  </tr>


</table>
</body>
</html>

最佳答案

我很想在一个查询中选择表中的所有行,然后使用 JavaScript(或 jQuery)更改选择列表选项。这可以节省 HTTP 请求,因为每次更改都会触发 AJAX 事件,如果用户更改选项 100 次,则仅出于美观原因就需要 100 个请求。

另一个好处是,如果用户由于某种原因没有 JavaScript 或连接速度较慢,那么选择列表仍然可用,否则它们将是空白的,因为它们尚未被 AJAX 加载打电话。

关于php - 我们如何使用数据库动态更改一些下拉列表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10208903/

相关文章:

php - 在 PHP 中初始化(空)数组的最佳方法

php - 如何使用fileuploadfield extjs + php上传图片

php - 在没有表单的情况下使用 vuejs 和 laravel 上传文件

javascript - 我应该用哪种方式调用 Javascript 中继承的静态方法?

mysql - 宏无法获取正确的数据透视表名称

c# - 如何防止 MyISAM 大表崩溃

java - Spring - 仅在保存/POST 时出现 'field list' 中的未知列(但读取/GET 有效...)

php - 根据另一个下拉列表填充下拉列表的最佳和最简单方法是什么

javascript - jquery(或纯js)模拟按下回车键进行测试

javascript - 在 google maps api v3 中完成多边形绘制时的处理