Mysql
 sql >> Datenbank >  >> RDS >> Mysql

PHP:Dynamisches Drop-down mit optgroup

Die beiden for-Schleifen sind in Ihrem Code nicht verschachtelt:

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 } ?>

Das Ergebnis ist, dass zuerst alle Opt-Gruppen erstellt werden und dann die Mitarbeiter für die letzte Gruppe hinzugefügt werden (weil $label und $opt sind auch nach Beendigung der Schleife verfügbar).

Sie müssen die Schleifen verschachteln (unter Verwendung alternativer Syntax zur Steuerung Strukturen ):

<?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; ?>

Außerdem denke ich, dass Sie die emp_id verwenden müssen , nicht die grp_id beim Erstellen des Arrays:

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