0

我有一个问题,希望有更多经验的人可以帮助我。

我有一个包含以下字段及其值的表​​​:

编号 | 类型 | 颜色
----|---------|--------
1 | 裤子 | 蓝色
2 | 裤子 | 绿色
3 | 裤子 | 红
4 | 衬衫 | 眉头
5 | 衬衫 | 粉红色
6 | 衬衫 | 红色的

我想做的是根据所选服装的类型过滤掉颜色。

示例:如果我只选中复选框“pants”,则返回值​​''蓝色、绿色、红色。” 如果我只选中复选框“衬衫”,则返回值​​''棕色,粉红色,红色。“但是现在我想选中两个复选框,我希望结果是“蓝色,棕色,绿色,粉红色,红色的。”

有谁知道我该怎么做?

注意:我的语言不是英语,如果有错误请见谅。

使用的文件:

索引.php

<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>Checkbox</title>
        <script type="text/javascript" src="jquery-1.10.2.js"></script>
        <script type="text/javascript">
            $(document).ready(function() {
                $("input[name='type']").click('change', function() {
                    $("#colors").html('Loading colors...');
                    $.post("colors.php", {type: $(this).val()}, function(valor) {
                        $("#colors").html(valor);
                    });
                });
            });
        </script>
    </head>
    <body>
        <p><?php require_once './types.php'; ?></p>
        <p id="colors"></p>
    </body>
</html>

类型.php

<?php

require_once './connection.php';

$sql = "SELECT DISTINCT types FROM test";
$con = mysql_query($sql);

if (mysql_num_rows($con) === 0) {
    echo '0 result(s)';
} else {
    while ($row = mysql_fetch_assoc($con)) {
        echo '<input type="checkbox" name="type" value="' . $row['types'] . '"> ' . $row['types'];
    }
}

?>

颜色.php

<?php

require_once './connection.php';

$type = $_POST['type'];

$sql = "SELECT DISTINCT colors FROM test WHERE types = '$type'";
$con = mysql_query($sql);

if (mysql_num_rows($con) === 0) {
    echo '0 result(s)';
} else {
    while ($row = mysql_fetch_assoc($con)) {
        echo $row['colors'] . '<br>';
    }
}

?>
4

1 回答 1

0

命名您的复选框type[],这将允许您获取类型数组。

然后将您的颜色查询调整为:

$types = "'".implode("','",array_map("mysql_real_escape_string",$_POST['type']))."'";
$sql = "SELECT DISTINCT `colors` FROM `test` WHERE `types` IN (".$types.")";
于 2013-11-04T18:13:35.237 回答