1

使用这行代码,我将每个选定复选框的值添加到数据库中:

    // ADD ALL TYPES TO PRODUCTIONLOG_TYPE TABLE
    $x=1;
    $values=array();
    foreach($_POST['id'] as $x)
    {
        $AddToListQuery = "
                        INSERT INTO
                        productionlog_type
                       (productionlogid, typeid)
                        VALUES
                       ('" . mysql_real_escape_string($_GET['productionlog']) . "', '". mysql_real_escape_string($x) ."')
                       ";
        mysql_query($AddToListQuery)or die("query fout " . mysql_error() );
    }

我这样做是为了回显已选中的复选框是否已在数据库中。

现在的问题是,当用户取消选中复选框并发送表单时,它没有传递任何值,对吧?所以我不能从数据库中删除它......意味着复选框仍然处于选中状态。

我能做些什么呢?

4

1 回答 1

2

如果您知道将返回哪些复选框,则可以过滤掉您知道的那些复选框,然后只保留未选中的复选框。

您还可以在发送请求之前查看页面的某些处理,例如使用 JavaScript。

或者,您可以在表单中传递另一个隐藏变量,其中包含您应该在 PHP 脚本中收到的所有复选框。例如:

<input type="hidden" value="id_1,id_2,id_3" />

如果您随后在 PHP 脚本中收到此信息,您可以看到(复选框的)哪些 id 是预期的。


编辑

如果你有:

<form method="POST">
    <input type="hidden" name="checks" value="id1,id2" />
    <input type="checkbox" name="id1" checked="checked" />
    <input type="checkbox" name="id2" />
</form>

然后在 PHP 中:

$arr = split(",", $_POST["checks"]);
foreach ($arr as $x){
    if(isset($_POST[$x])){
        // Add or update
    }else{
        // Remove
    }
}

注意:我没有测试过代码,但你只是想了解它是如何工作的

于 2012-12-18T11:20:50.370 回答