我已经尝试过这段代码,这些代码在我的template.php中由drupal开发人员在很多例子中使用,但是当我打印出$ variables数组时,它不包含任何名为“tree”的键。我只需要在菜单块中添加ul li标签,但
function atsubtheme_menu_tree(&$variables) {
return '<ul class="nav">' . $variables['tree'] . '</ul>';
}
这就是我使用以下代码在page.tpl上呈现菜单的方法,该代码在drupal菜单的主菜单下有一个链接列表
<nav id="menu">
<h2>Menu</h2>
<?php print render($page['menu_bar']); ?>
</nav>
我只需要在ul li标签中找到这个菜单。
答案 0 :(得分:1)
是的,我也用菜单drupal渲染器补偿,这就是为什么我更喜欢编写自己的渲染(在page.tpl.php中):
<ul class="nav">
<?php
$mymenu = menu_tree('main-menu');
foreach($mymenu as $item){
if(!empty($item['#title'])){
$attributes = array('class'=>array('all', 'my', 'classes'), 'id'=>'an-eventual-id');
print '<li>'.l($item['#title'],$item['#href'],array('attributes'=>$attributes)).'</li>';
}
}
?>
</ul>
答案 1 :(得分:0)
我遇到的一种更简单的方法
function YOURTHEMENAME_menu_tree($variables) {
return '<ul class="mycustmenu">' . $variables['tree'] . '</ul>';
//wrapping the menu in ul tags
}
function YOURTHEMENAME_menu_link($variables) {
$element = $variables['element'];
$sub_menu = '';
if ($element['#below']) {
$sub_menu = drupal_render($element['#below']);
//if your menu has a sub menu
}
$output = l($element['#title'], $element['#href'],$element['#localized_options']);
return '<li>' . $output . $sub_menu . "</li>\n";
//wrapping each list item in li tags
}