sql >> Database >  >> RDS >> Mysql

PHP:Dynamische drop-down met optgroup

De twee for-lussen zijn niet genest in uw 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 } ?>

Het resultaat is dat eerst alle opt-groepen worden aangemaakt en vervolgens de medewerkers voor de laatste groep worden toegevoegd (omdat $label en $opt zijn ook beschikbaar nadat de lus is voltooid).

Je moet de lussen nesten (gebruikmakende van alternatieve syntaxis voor controle structuren ):

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

Verder denk ik dat je de emp_id . moet gebruiken , niet de grp_id bij het maken van de array:

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



  1. Mysql commode engine MyISAM naar InnoDB

  2. Hoe gegevens van mysql weergeven met behulp van angular.js PHP?

  3. Php multi-dimensionale array van mysql resultaat

  4. Ruby on Rails - kan zo'n bestand niet laden -- mysql2/2.2/mysql2 (LoadError)