duana1986 2011-02-11 21:33
浏览 51
已采纳

如何在PHP(noob)中从数组创建嵌套列表

I have an app that users choose items and then it fills a table that has two columns in it: Category and Items. Its something like this:

Category  | Items 
-----------------
PET       | Dog Food
HEALTH    | Tooth Brush
PET       | Cat Food
COLD FOOD | Steak
COLD FOOD | Eggs

In my select statement I order the data by Category then by Items and I am using a WHILE loop to drop the data into an array.

while($listItems = mysql_fetch_array($results))
{
    $myArray[] = array("category" => $listItems["Category"],
                       "item"     => $listItems["Name"]);
}

When I do a print_r($myArray); I get something like this:

Array ( [0] => Array ( [category] => Cold Food [item] => Steak )
        [1] => Array ( [category] => Food      [item] => Eggs )
        [2] => Array ( [category] => Health    [item] => Tooth Brush )
        [3] => Array ( [category] => Pet       [item] => Cat Food )
        [4] => Array ( [category] => Pet       [item] => Dog Food ) )

What I am wanting to do is output the data into a nested list something like this.

  • Cold Food
    • Steak
    • Eggs
  • Health
    • Tooth Brush
  • Pet
    • Cat Food
    • Dog Food

Any help is welcomed! Thanks!

  • 写回答

4条回答 默认 最新

  • dongwei4652 2011-02-11 21:43
    关注

    Try this:

    while($listItems = mysql_fetch_array($results))
    {
        $cat  = $listItems['Category'];
        $name = $listItems['Name'];
    
        if(!isset($myArray[$cat]))
          $myArray[$cat] = array();
    
        $myArray[$cat][] = $name;
    }
    

    Then, to output it you'd do this:

    $buffer = '<ul>';
    foreach($myArray as $cat => $items) {
       $buffer .= "<li>$cat</li><li><ul>";
       foreach($items as $item) {
          $buffer .= "<li>$item</li>";
       }
       $buffer .= '</ul></li>';
    }
    $buffer .= '</ul>';
    echo $buffer;
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
  • ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)
  • ¥15 相敏解调 matlab
  • ¥15 求lingo代码和思路
  • ¥15 公交车和无人机协同运输
  • ¥15 stm32代码移植没反应
  • ¥15 matlab基于pde算法图像修复,为什么只能对示例图像有效
  • ¥100 连续两帧图像高速减法
  • ¥15 如何绘制动力学系统的相图
  • ¥15 对接wps接口实现获取元数据