sql >> Database teknologi >  >> RDS >> Mysql

PHP:Dynamisk dropdown med optgroup

De to for loops er ikke indlejret i din kode:

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

Resultatet er, at alle opt-grupper først oprettes, og derefter tilføjes medarbejderne for den sidste gruppe (fordi $label og $opt er også tilgængelige efter løkken er færdig).

Du skal indlejre løkkerne (ved at bruge alternativ syntaks til kontrol strukturer ):

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

Desuden tror jeg, du skal bruge emp_id , ikke grp_id når du opretter arrayet:

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



  1. Valg af datointerval MySQL med dato_format

  2. MySql.Data.MySqlClient.Replication.ReplicationManager kaster en System.TypeInitializationException

  3. Hvordan får jeg et resultat på tværs af 2 tabeller

  4. org.postgresql.util.PSQLEundtagelse:FATAL:beklager, for mange klienter allerede