如何使子菜单URL遵循树层次结构

时间:2014-05-31 08:53:54

标签: php

我的网站上有自定义菜单,我想让网址遵循树层次结构。

目前发生了什么:

www.example.com/menu-5

这应该是输出

www.example.com/menu-2/menu-5

这意味着menu-5是menu-2的子节点。它已经添加到数据库中。

/* Recursive Admin Menu */
    function recursive_list_pages( $array = array(), $content_parent = 0 ){

        if( !empty($array[$content_parent]) ){

            /* Conditional to check if the module is parent and addClass to its ul */
            $addClass = '';
            if( $content_parent == 0 ){
                $addClass = 'class="menu menu-level-' . $content_parent . '"';
            } else if( $content_parent > 0 ){
                $addClass = 'class="submenu menu-level-' . $content_parent . '"';
            }

            echo '<ul ' . $addClass . '>';
            foreach( $array[$content_parent] as $items ){

            /* Conditional to check if the module is parent and addClass, attr to its li */
            $addClassli = '';
            if( $content_parent == 0 ){
                $addClassli = 'class="menu-item menu-item-' . $items["content_id"] . '"';
            } else if( $content_parent > 0 ){
                $addClassli = 'class="submenu-item submenu-item-' . $items["content_id"] . '"';
            }

                echo '<li ' . $addClassli . '>';
                    echo '<a href="' . SITE_URL . '' . $items["content_slug"] . '">';
                    echo $items["content_title"];
                    echo '</a>';
                    recursive_list_pages( $array, $items["content_id"] );
                echo '</li>';

            }
            echo '</ul>';
        }
    }



/* Get Menu from Database */
    function list_pages(){
        global $db;
        $sql = "SELECT * FROM hpl_content WHERE content_type='pages' ORDER BY content_sort ASC";
        $query = $db->SELECT($sql);
        $array = array();
        if( $db->NUM_ROWS() > 0 ){
            $rows = $db->FETCH_ARRAY();
            foreach( $rows as $row ){ $array[$row["content_parent"]][] = $row; }
            recursive_list_pages( $array );
        }
    }

请帮忙。

1 个答案:

答案 0 :(得分:1)

尝试类似:

/* Recursive Admin Menu */
function recursive_list_pages( $array = array(), $content_parent = 0,$parent_slug = null){

    if( !empty($array[$content_parent]) ){

        /* Conditional to check if the module is parent and addClass to its ul */
        $addClass = '';
        if( $content_parent == 0 ){
            $addClass = 'class="menu menu-level-' . $content_parent . '"';
        } else if( $content_parent > 0 ){
            $addClass = 'class="submenu menu-level-' . $content_parent . '"';
        }

        echo '<ul ' . $addClass . '>';
        foreach( $array[$content_parent] as $items ){

        /* Conditional to check if the module is parent and addClass, attr to its li */
        $addClassli = '';
        if( $content_parent == 0 ){
            $addClassli = 'class="menu-item menu-item-' . $items["content_id"] . '"';
        } else if( $content_parent > 0 ){
            $addClassli = 'class="submenu-item submenu-item-' . $items["content_id"] . '"';
        }

            echo '<li ' . $addClassli . '>';
            if(is_null($parent_slug)) {
                echo '<a href="' . SITE_URL . $items["content_slug"] . '">';
            } else {
                echo '<a href="' . SITE_URL . $parent_slug . '/' . $items["content_slug"] . '">';
            }

                echo $items["content_title"];
                echo '</a>';
                recursive_list_pages( $array, $items["content_id"], $items['content_slug']);
            echo '</li>';

        }
        echo '</ul>';
    }
}

如果您没有通过父ID订购商品(结果是:父母1,父母1的第一个孩子,父母1的第二个孩子,父母2,父母2的第一个孩子等),我认为你应该。

但基本上你需要传递父母的slug,并且子链接会在他们自己的slug之前附加父slug。