sql >> Databasteknik >  >> RDS >> Mysql

PHP:Dynamisk rullgardinsmeny med optgroup

De två för loopar är inte kapslade i din kod:

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 är att först skapas alla opt-grupper och sedan läggs de anställda för den sista gruppen till (eftersom $label och $opt finns också tillgängliga efter att slingan är klar).

Du måste kapsla slingorna (med alternativ syntax för kontroll 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; ?>

Dessutom tror jag att du måste använda emp_id , inte grp_id när du skapar arrayen:

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



  1. Hur man lägger till en separator till en sammanfogad sträng i SQL Server – CONCAT_WS()

  2. Rum - Använder externa SQLites såväl som intern DB

  3. PHP, ORM, MSSQL och Unicode, är det möjligt att få dessa att fungera tillsammans?

  4. SLIP TABELL OM FINNS Exempel i PostgreSQL