sql >> Database >  >> RDS >> Mysql

Recursie gebruiken om navigatie te bouwen

Hier is een voorbeeld met recursie.

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);

Dat script produceert de volgende uitvoer:

<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>


  1. Een enkel eindpunt maken voor uw PostgreSQL-replicatie-installatie met behulp van HAProxy

  2. Een SQL Server-database herstellen (T-SQL)

  3. 2 manieren om de karaktersets beschikbaar te krijgen in MariaDB

  4. java.lang.NoSuchFieldError:GEEN in winterslaap met Spring 3, maven, JPA, c3p0