Mysql
 sql >> Base de données >  >> RDS >> Mysql

PHP :liste déroulante dynamique avec optgroup

Les deux boucles for ne sont pas imbriquées dans votre code :

foreach ($groups as $label => $opt) { ?>
    <optgroup label="<?php echo $label; ?>">
<?php   } <-- wrong here
    foreach ($groups[$label] as $id => $name) { ?>
        <option value="<?php echo $id; ?>"><?php echo $name; ?></option>
<?php } ?>

Le résultat est que tous les groupes opt sont d'abord créés, puis les employés du dernier groupe sont ajoutés (car $label et $opt sont également disponibles une fois la boucle terminée).

Vous devez imbriquer les boucles (en utilisant une syntaxe alternative pour le contrôle structures ):

<?php foreach($groups as $label => $opt): ?>
    <optgroup label="<?php echo $label; ?>">
    <?php foreach ($opt as $id => $name): ?>
        <option value="<?php echo $id; ?>"><?php echo $name; ?></option>
    <?php endforeach; ?>
    </optgroup>
<?php endforeach; ?>

De plus, je pense que vous devez utiliser le emp_id , pas le grp_id lors de la création du tableau :

while ($qa = $employees->GetRows()) {
    $groups[$qa['groupname']][$qa['emp_id']] = $qa['empname'];
}