2

这是我的代码:

<div class="widgeter-content no-padding">
    <ul id="contacts">
        <?php
        while ($r = mysql_fetch_array($q)){
            $currentletter = substr($name,0,1);
            if ($currentletter != $lastletter){
            ?>
            <!-- start li data group for specific alphabetic letter -->
            <li data-group="<?=$currentletter;?>">
                <a class="title"><?=strtoupper($currentletter);?></a>
            <?
            }
            ?>
                <ul>
                    <li>
                        <a href="#">
                            <span><?=$name;?></span>
                        </a>
                    </li>
                </ul>
            <?
            if ($currentletter != $lastletter){
            ?>
            </li>
            <!-- end data group (not currently working, ends on first result) -->
            <?
            }
            $lastletter = $currentletter; 
        }
        ?>
    </ul>
</div>

我正在尝试做的事情:

A:

Alfred
Annie

B:

Bob
Billy

如您所见,数据被包装在一个 li 数据组中。

代码的第一部分完美运行,但最后一部分(我试图将结束 li 标签放在结束注释之前,显示在每个循环的第一个结果之后,它需要显示在每个字母的末尾结果)。

最好的方法是什么?我确信我想要实现的目标非常明显,但我想不出一种合乎逻辑的方式来让代码按照我想要的方式构建。

谢谢

4

2 回答 2

1
    $res      = array();
    while ($r = mysql_fetch_array($q)){
      $currentletter = substr($name,0,1);
      $res[$currentletter][]  = $name;
    }

    foreach($res as $key=>$val){
       /// here you add your li
       /// here $key will give you letter and $val will give you name
       echo $key;
       foreach($val as $reqvals){
          echo $reqvals;
          echo "<br>";
       }
    }
于 2013-01-29T05:16:05.780 回答
0

最好的方法是什么?

如果您从数据库中获取行,为什么不能在那里进行 GROUP BY 并获取记录。这是首选的方法。

假设列名是first_name

group by substr(first_name,1,1)
于 2013-01-29T05:15:42.390 回答