我的网站上有自定义菜单,我想让网址遵循树层次结构。
目前发生了什么:
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 );
}
}
请帮忙。
答案 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。