我有这段代码:
<?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>
我希望使用以下代码从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]'总是空的。有人可以帮我吗?提前谢谢!
答案 0 :(得分:0)
ans1
和ans2
作为阵列发送到服务器。不是字符串。将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;'>";
}
'
)以便更好地阅读。name='ans2[$row[col_id]]'
(它现在是一个数组)$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
}
}