我正在尝试从复选框中获取各个值,
$mail_aspects['active']
和$mail_aspects['aspect_id']
。
但是使用下面的代码,我只能获得$mail_aspects['active']=1
的值。但我需要在DB中更新已检查和未检查的值。
有人可以帮忙解决这个问题吗?
<form method='post' style='display: inline-block;'>
<div class="col-md-12">
<?foreach ($customer['mail_aspects'] as $mail_aspects)
{ ?>
<table>
<tr>
<td>
<label>
<input type="checkbox" name="mail_aspects[]" <?=($mail_aspects['active'] == '1') ? 'checked' : ''?>
value="<?=$mail_aspects['active']?>,<?=$mail_aspects['aspects_id']?>">
<?=$mail_aspects['aspects_name']?>
</label>
</td>
</tr>
</table>
<? }?>
</div>
<button type='submit' name='submit' value='Submit'>Save Aspects</button>
</form>
使用PHP
if(isset($_POST['submit'])){
$mail_aspectsdet=$_POST['mail_aspects'];
for($i=0;$i<count($mail_aspectsdet);$i++)
{
$exp=explode(',',$mail_aspectsdet[$i]);//Explode id and name
$stmt=$db->exec("UPDATE customer_preferences set active=$exp[0] where customer_id=$customerID and aspects_id=$exp[1]");
}
}
答案 0 :(得分:0)
要在$ _POST中接收未经检查的复选框值,您必须在添加复选框之前添加具有相同名称和空值的隐藏输入字段。如果未选中复选框,则将提交隐藏输入的空值,否则将提交复选框的值。
在您的情况下,它应该看起来像:
<form method='post' style='display: inline-block;'>
<div class="col-md-12">
<?foreach ($customer['mail_aspects'] as $mail_aspects)
{ ?>
<table>
<tr>
<td>
<label>
<input type="hidden" name="mail_aspects[<?=$mail_aspects['aspects_id']?>]" value="0" />
<input type="checkbox" name="mail_aspects[<?=$mail_aspects['aspects_id']?>]" <?=($mail_aspects['active'] == '1') ? 'checked' : ''?>
value="1">
<?=$mail_aspects['aspects_name']?>
</label>
</td>
</tr>
</table>
<? }?>
</div>
<button type='submit' name='submit' value='Submit'>Save Aspects</button>
</form>
重要的是隐藏名称和复选框输入名称相同。
您的PHP代码应该可以正常运行。