微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PHP / MySQL构建树菜单

我正在尝试使用 PHPMysqL中的数据库构建一个未提供的列表菜单树.

我有一个数据库返回的页面对象数组.每个页面对象都有parent_id属性,如果它没有父属性,则设置为null.这是页面对象的样子:

page object
  id
  title
  parent_id

如果可能的话,我不想以递归方式执行,只打了一次数据库,因为我将在几乎每个请求上构建菜单.我想创建一个函数,我可以将我的对象数组传递给它,它将返回html列表.

我喜欢@ mario的解决方案,并且通过防止过量的< ul>对其进行了改进.我建议您在SQL查询中执行ORDER BY以按照您想要的顺序获取菜单(甚至可以建议将权重/序列列添加到模式中.

数据设置:

$menu = array( // Presumed to have been coming from a sql SELECT,populated for demo.
  array('id'=>1,'title'=>'Menu 1','parent_id'=>null),array('id'=>2,'title'=>'Sub 1.1','parent_id'=>1),array('id'=>3,'title'=>'Sub 1.2',array('id'=>4,'title'=>'Sub 1.3',array('id'=>5,'title'=>'Menu 2',array('id'=>6,'title'=>'Sub 2.1','parent_id'=>5),array('id'=>7,'title'=>'Sub Sub 2.1.1','parent_id'=>6),array('id'=>8,'title'=>'Sub 2.2',array('id'=>9,'title'=>'Menu 3',);

处理:

function has_children($rows,$id) {
  foreach ($rows as $row) {
    if ($row['parent_id'] == $id)
      return true;
  }
  return false;
}
function build_menu($rows,$parent=0)
{  
  $result = "<ul>";
  foreach ($rows as $row)
  {
    if ($row['parent_id'] == $parent){
      $result.= "<li>{$row['title']}";
      if (has_children($rows,$row['id']))
        $result.= build_menu($rows,$row['id']);
      $result.= "</li>";
    }
  }
  $result.= "</ul>";

  return $result;
}
echo build_menu($menu);

输出

<ul>
  <li>Menu 1<ul>
    <li>Sub 1.1</li>
    <li>Sub 1.2</li>
    <li>Sub 1.3</li>
  </ul></li>
  <li>Menu 2<ul>
    <li>Sub 2.1<ul>
      <li>Sub Sub 2.1.1</li>
    </ul></li>
    <li>Sub 2.2</li>
  </ul></li>
  <li>Menu 3</li>
</ul>

原文地址:https://www.jb51.cc/php/135324.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐