使用递归来构建导航

Mik*_*ike 5 php mysql recursion

我正在为一个站点构建导航,对于我的生活,我无法弄清楚递归.我使用这种设计通过MySQL存储了所有数据:

在此输入图像描述

我已经阅读了几个关于递归如何工作的链接,我一定很慢,因为我很难掌握.我试着写一些东西,我知道它甚至不是我真正需要的东西,但它是一个开始:

PDO

public function viewCategories()
{
    $viewSQL = "SELECT * FROM categories";  
    try
    {
        $pdo = new PDO('mysql:host=localhost;dbname=store','root','');
        $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
        $categoryVIEW = $pdo->prepare($viewSQL);
        $categoryVIEW->execute();
        $array = $categoryVIEW->fetchAll(PDO::FETCH_ASSOC);
        $categoryVIEW->closeCursor();
        $json = json_encode($array);
        return $json;
    }
    catch(PDOexception $e)
    {
        return $e->getMessage();
        exit();
    }
}
Run Code Online (Sandbox Code Playgroud)

递归

$return = json_decode($category->viewCategories(),true);

function buildNavigation($json)
{
    foreach($json as $item)
    {
        if($item['category_id'] === $item['parent'])
        {
            print('<li>'.$item['category_name'].'</li>');
            if($item['category_id'] === $item['parent'])
            {
                print('<li>match'.$item['category_name'].'</li>');
                buildNavigation($json);
            }
        }
}
buildNavigation($return);
Run Code Online (Sandbox Code Playgroud)

正如预期的那样,这将永远不会进入.我确实试图通过自己来解决这个问题,因为知道这是一件好事,但我想这超出了我的心理能力:(

谢谢你看看:)

UPDATE

我知道这已经得到了解答,但有没有办法可以做到这一点来构建一个关联数组?我一直在玩一个ALMOST为我工作的功能,我从这里获得,但它增加了一个我不想要的额外数组.

方法

private function buildCategories($array,$parent)
{
    $result = array();
    foreach($array as $row)
    {
        if($row['parent'] == $parent)
        {
            $result[$row['category_name']] = $this->buildCategories($array,$row['category_id']);
        }
    }
    return $result;
}
$json = json_encode($this->buildCategories($array,NULL));
return $json;
Run Code Online (Sandbox Code Playgroud)

我要这个:

{"reloading":{"components","presses and dies","tumblers & scales","tools & accessories","shotshell reloading"}
Run Code Online (Sandbox Code Playgroud)

但我得到的是这个:

{"reloading":{"components":[],"presses and dies":[],"tumblers & scales":[],"tools & accessories":[],"shotshell reloading":[]}
Run Code Online (Sandbox Code Playgroud)

Max*_*rin 15

这是一个递归的例子.

function buildNavigation($items, $parent = NULL)
{
    $hasChildren = false;
    $outputHtml = '<ul>%s</ul>';
    $childrenHtml = '';

    foreach($items as $item)
    {
        if ($item['parent'] == $parent) {
            $hasChildren = true;
            $childrenHtml .= '<li>'.$item['category_name'];         
            $childrenHtml .= buildNavigation($items, $item['category_id']);         
            $childrenHtml .= '</li>';           
        }
    }

    // Without children, we do not need the <ul> tag.
    if (!$hasChildren) {
        $outputHtml = '';
    }

    // Returns the HTML
    return sprintf($outputHtml, $childrenHtml);
}

print buildNavigation($items);
Run Code Online (Sandbox Code Playgroud)

该脚本生成以下输出:

<ul>
    <li>Menu 1</li>
    <li>Menu 2
        <ul>
            <li>Sub Menu 2.1</li>
            <li>Sub Menu 2.2</li>
            <li>Sub Menu 2.3
                <ul>
                    <li>Sub Menu 2.2.1</li>
                    <li>Sub Menu 2.2.2</li>
                    <li>Sub Menu 2.2.3</li>
                </ul>
            </li>
        </ul>
    </li>
    <li>Menu 3</li>
</ul>
Run Code Online (Sandbox Code Playgroud)