0

我目前正在回显来自查询的数组,我需要将它们呈现在嵌套的无序列表中。我正在尝试找到一种方法来无限地执行此过程,因为我目前正在手动回显每个嵌套的 ul(如果它们有的话),直到我手动编码的深度。如果有办法自动回显 ul 的深度“n”,请帮助我。

这是我目前的逻辑,只回显到深度 5:

<ul class="parent_tree"><?php
  foreach($category_tree as $category_level_1)
  {
    echo '<li><a href="#">' . $category_level_1['name'] . '</a>';

    if(array_key_exists('children', $category_level_1))
    {
      echo '<ul>';

      foreach($category_level_1['children'] as $category_level_2)
      {
        echo '<li><a href="#">' . $category_level_2['name'] . '</a>';

        if(array_key_exists('children', $category_level_2))
        {
          echo '<ul>';

          foreach($category_level_2['children'] as $category_level_3)
          {
            echo '<li><a href="#">' . $category_level_3['name'] . '</a>';

            if(array_key_exists('children', $category_level_3))
            {
              echo '<ul>';

              foreach($category_level_3['children'] as $category_level_4)
              {
                echo '<li><a href="#">' . $category_level_4['name'] . '</a>';

                if(array_key_exists('children', $category_level_4))
                {
                  echo '<ul>';

                  foreach($category_level_4['children'] as $category_level_5)
                  {
                    echo '<li><a href="#">' . $category_level_5['name'] . '</a>';

                    //level 6 goes here

                    echo '</li>';
                  }

                  echo '</ul>';
                }

                echo '</li>';
              }

              echo '</ul>';
            }

            echo '</li>';
          }

          echo '</ul>';
        }

        echo '</li>';
      }

      echo '</ul>';
    }

    echo '</li>';
  }
?>
</ul>
4

1 回答 1

1

尚未对其进行测试,但您想为此使用递归。基本上,您继续使用不同的参数调用相同的函数。当没有更多子数组时,它将遍历所有内容并退出。

function recursive_list($category) {
    echo '<ul>';
    foreach($category as $item){
        echo '<li><a href="#">' . $item['name'] . '</a>';
        if(array_key_exists('children', $item)) {
            recursive_list($item);
        }
    }
}
于 2013-02-21T04:15:01.337 回答