У меня есть форма с множественным выбором в цикле while:
while ($row_i = mysql_fetch_array($res_i))
{
$i++;
// maak select name
$name_bewerking_id = 'bewerking_id'.$i;
?>
<tr valign="top">
<td>
<select name="<?php echo $name_bewerking_id ?>[]" multiple="multiple" size="2">
<?php
$sql = "SELECT id, bewerking FROM bewerkingen ORDER BY bewerking ASC";
$res = mysql_query($sql,$con);
while ($row = mysql_fetch_assoc($res))
{ ?>
<option value="<?php echo $row['id']; ?>"><?php echo $row['bewerking']; ?></option>
<?php } ?>
</select>
</td>
</tr>
<?php
}
При отправке формы:
$bewerking_id[$i] = array();
$bewerking_id[$i] = $_POST['name_bewerking_id'][$i];
if(isset($bewerking_id_temp[$i]))
{
foreach($bewerking_id_temp[$i] as $temp[$i])
{
array_push($bewerking_id[$i], $temp[$i]);
}
}
Возвращаясь к форме:
for ($i = 0; $i <= $aantal_regels_corr; $i++)
{
// maak select name
$name_bewerking_id = 'bewerking_id'.$i;
?>
<tr valign="top">
<td>
<select name="<?php echo $name_bewerking_id ?>[]" multiple="multiple" size="2">
<?php
$sql = "SELECT id, bewerking FROM bewerkingen ORDER BY bewerking ASC";
$res = mysql_query($sql,$con);
while ($row = mysql_fetch_assoc($res))
{ ?>
<option <?php if(isset($bewerking_id[$i]) && in_array($row['id'], $bewerking_id[$i])){ echo 'selected="selected"'; } ?> value="<?php echo $row['id']; ?>"><?php echo $row['bewerking']; ?></option>
<?php } ?>
</select>
</td>
</tr>
<?php
}
При возврате в форму (когда одно из других полей не заполнено) выбранные параметры теряются и не выбираются снова.
Где я все испортил?