sql >> データベース >  >> RDS >> Mysql

PHP:optgroupを使用した動的ドロップダウン

    2つのforループはコードにネストされていません:

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

    その結果、最初にすべてのoptグループが作成され、次に最後のグループの従業員が追加されます($labelのため) および$opt ループが終了した後も利用できます。

    ループをネストする必要があります(制御に代替構文を使用する構造 ):

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

    さらに、emp_idを使用する必要があると思います 、grp_idではありません アレイを作成するとき:

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



    1. MySQL utf8mb4、絵文字を保存するときのエラー

    2. バイナリとしてのUUIDの挿入と選択(16)

    3. 先行ゼロのLPAD

    4. pg-promiseで親と子のツリーを取得します