2

我有这个代码:

<?php
$result = mysqli_query($con,"SELECT * FROM table");

while($row = mysqli_fetch_array($result)){
echo "<input type=\"checkbox\" id=\"$row[use_id]\"  name=\"things[]\"  value='$row[col_id]' >$row[col]<br>";
echo "<input placeholder=\"description\" type=\"text\" name=\"ans1\" class='$row[col_id]' id=\"answer1\" style='display:none;'>";
echo "<align='left'><input placeholder=\"source\" type=\"text\" name=\"ans2\" class='$row[use_id]' id=\"answer2\"   style='display:none;'>";

}
?>

使用这个脚本:

<script>
$(document).ready(function(){


 $("input[type=checkbox]").change(function(){
    var divId = $(this).attr("id");

     if ($(this).is(":checked")){
        $("." + divId).show();
     }
     else{
         $("." + divId).hide();
     }
});
});
</script>

我想使用 ths 代码从 2 个文本框中获取数据:

$checkBox = $_POST['things'];


for($i=0; $i<sizeof($checkBox); $i++){


    $qs = "INSERT INTO sccm_reherb.table2 values('$_POST[id]','".$checkBox[$i]."','$_POST[ans1]','$_POST[ans2]')";
    echo $qs;
    mysqli_query($con,$qs) or die(mysqli_error($con));
}

但 '$_POST[ans1]' 和 '$_POST[ans2]' 总是空的..谁能帮帮我?提前致谢!

4

1 回答 1

0

您必须将ans1ans2作为数组发送到服务器。不是作为字符串。

while将您的循环更改为:

while($row = mysqli_fetch_array($result)) {
    echo "<input type='checkbox' id='$row[use_id]'  name='things[$row[col_id]]'  value='$row[col_id]' >$row[col]<br>";
    echo "<input placeholder='description' type='text' name='ans1[$row[col_id]]' class='$row[col_id]' id='answer1' style='display:none;'>";
    echo "<align='left'><input placeholder='source' type='text' name='ans2[$row[col_id]]' class='$row[use_id]' id='answer2'   style='display:none;'>";
}
  • 注 1:'为了更好地阅读,我在 HTML 属性中使用了单引号 ( )。
  • 注2:注意name='ans2[$row[col_id]]'(现在是数组)
  • 注3:我手动设置数组的索引$row[col_id]

现在,如果您将此表单发送到服务器,您将得到这样的结果:

Array
(
    [things] => Array
        (
            [1] => 1
            [4] => 4
        )

    [ans1] => Array
        (
            [1] => Description 1
            [2] => forbidden data by user
            [3] => forbidden data by user
            [4] => Description 4
            [5] => forbidden data by user
        )

    [ans2] => Array
        (
            [1] => Source 1
            [2] => forbidden data by user
            [3] => forbidden data by user
            [4] => Source 4
            [5] => forbidden data by user
        )

)

在上面的数组中,所有文本框都有我在那里写的值forbidden data by user。这并不重要,因为有效数据(用户已选中复选框)是things数组中的数据,因此在服务器中,您必须循环该数组。

$checkbox = $_POST['things'];

if ($checkbox) {
    foreach ($checkbox as $id => $value) {
        $ans1 = $_POST['ans1'][$id];
        $ans2 = $_POST['ans2'][$id];

        // to other stuff
    }
}
于 2013-05-22T12:57:34.043 回答