当前位置: 首页 > 面试题库 >

PHP / MySQL构建树菜单

汤念
2023-03-14
问题内容

我正在尝试从我的PHP和MySQL数据库中构建一个不被接受的列表菜单树。

我有一个从数据库返回的页面对象数组。每个页面对象都有parent_id属性,如果没有父对象,则将其设置为null。页面对象如下所示:

page object
  id
  title
  parent_id

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


问题答案:

我喜欢@mario的解决方案,并在防止过度使用方面进行了改进<ul>。我只是建议ORDER BY对您的SQL查询执行一个操作,以按您想要的顺序获取菜单(甚至可能建议将权重/序列列添加到架构中。

数据设置:

$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',         'parent_id'=>1),
  array('id'=>4,'title'=>'Sub 1.3',         'parent_id'=>1),
  array('id'=>5,'title'=>'Menu 2',          'parent_id'=>null),
  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',         'parent_id'=>5),
  array('id'=>9,'title'=>'Menu 3',          'parent_id'=>null),
);

处理:

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>


 类似资料:
  • 问题内容: 我必须建立一棵树,其中将包含约300个节点。该树没有深度限制。因此它可以具有3或15个级别。每个节点可以有无限数量的子代。 优先考虑的是尽可能快地获得完整的树/子树,但有时我也需要添加节点或移动节点,但并不是那么频繁。 我想知道在数据库中存储树的最佳方法以及在php中检索数据(如果可能)的最佳方法。 问题答案: 您可以使用 嵌套集模型, 因为它可以产生非常有效的查询。检出在MySQL中

  • pre { white-space: pre-wrap; } 为了创建异步的树形菜单(Tree),每一个树节点必须要有一个 'id' 属性,这个将提交回服务器去检索子节点数据。 创建树形菜单(Tree)     <ul id="tt"             url="tree2_getdata.php">     </ul> 服务器端代码     $id = isset($_POST['i

  • 问题内容: 所以,我的问题是,我想构建这两个表的树: 树应该看起来像: p p_0 p_0_0 p_0_1 p_0_1_0 p_0_1_1 q 有人可以帮我解决递归解决方案吗? 问题答案: 为此,您不需要在数据库中创建2个表,您可以仅从一个表中进行维护,如下所示 生成的数组将像 您需要使用下面的递归函数来实现它 该算法非常简单: 取所有元素的数组和当前父代的ID(最初为0 / nothing /

  • pre { white-space: pre-wrap; } 一个树形菜单(Tree)可以从标记创建。easyui 树形菜单(Tree)也可以定义在 <ul> 元素中。无序列表的 <ul> 元素提供一个基础的树(Tree)结构。每一个 <li> 元素将产生一个树节点,子 <ul> 元素将产生一个父树节点。 创建树形菜单(Tree)     <ul> <li>

  • pre { white-space: pre-wrap; } easyui 的树(Tree)插件允许您创建一个复选框树。如果您点击一个节点的复选框,这个点击的节点信息将向上和向下继承。例如:点击 'tomato' 节点的复选框,您将会看见 'Vegetables' 节点现在仅仅选中部分。 创建复选框树     <ul id="tt"             url="data/tree_data

  • 问题内容: 我环顾了互联网,但还没有完全找到想要的东西。我有一个平面数组,每个元素包含一个“ id”和一个“ parent_id”。每个元素只有一个父元素,但可能有多个子元素。如果parent_id = 0,则将其视为根级项目。我正在尝试将平面阵列变成一棵树。我发现的其他示例仅将元素复制到父元素,但原始元素仍然存在。 编辑 起始数组的每个元素都是从单独的XML文件中读取的。如果文件本身没有父文件,