我正在使用Joomla 2.5.8,我希望在网站的所有页面上都有一个辅助菜单,只显示主菜单中根菜单项#2的子菜单项。
Item 1 | Item 2 | Item 3 | Item 4
--- Show just the below items ---
| Item 2-1 |
| Item 2-2 |
| Item 2-3 |
| Item 2-4 |
我尝试过创建另一个菜单模块并设置开始和结束级别,但它只显示属于根菜单项的页面。
我也尝试过不设置开始和结束级别选项,只是使用模板css来隐藏我不想要的项目,但是当我隐藏根菜单项时我无法做到获取要显示的子菜单项。
我真的不想制作单独的菜单,因为如果主菜单有重大的菜单类型更改,我就不必再进行两次。
任何想法?
答案 0 :(得分:6)
这是我刚刚制作的模块。它从您选择的菜单项中呈现子菜单项。 在此处下载插件:Download
如果您无法下载或存在问题,请参阅以下插件文件:
PHP文件(mod_submenu.php
):
<ul class="menu">
<?php
defined('_JEXEC') or die;
$m = JFactory::getApplication()->getMenu();
$active = $m->getActive();
$active_id = isset($active) ? $active->id : $m->getDefault()->id;
$path = isset($active) ? $active->tree : array();
$menu = $m->getMenu();
$parentId = $params->get("menuitem");
foreach($menu as $item){
if($item->level == 2 && $item->parent_id == $parentId){
$class = 'item-'.$item->id;
if ($item->id == $active_id) {
$class .= ' current';
}
if (in_array($item->id, $path)) {
$class .= ' active';
}
$flink = $item->link;
if ((strpos($item->link, 'index.php?') === 0) && (strpos($item->link, 'Itemid=') === false)) {
$item->flink = $item->link.'&Itemid='.$item->id;
if (strcasecmp(substr($item->flink, 0, 4), 'http') && (strpos($item->flink, 'index.php?') !== false)) {
$item->flink = JRoute::_($item->flink, true, $item->params->get('secure'));
}
else {
$item->flink = JRoute::_($item->flink);
}
}
echo "<li class='$class'><a href='$item->flink'>$item->title</a></li>";
}
}
?>
</ul>
XML文件(mod_submenu.xml
):
<?xml version="1.0" encoding="utf-8"?>
<extension type="module" version="2.5.0" client="site" method="install">
<name>Show Submenu</name>
<author>Brian</author>
<creationDate>2012</creationDate>
<copyright></copyright>
<license>No license</license>
<authorEmail>No email</authorEmail>
<authorUrl>No website</authorUrl>
<version>1.0.0</version>
<description>Showing a submenu</description>
<files>
<filename module="mod_submenu">mod_submenu.php</filename>
<filename>index.html</filename>
</files>
<config>
<fields name="params">
<fieldset name="basic">
<field
name="menuitem"
type="menuitem"
label="Choose the menuitem" />
</fieldset>
</fields>
</config>
</extension>
(请原谅格式化,我仍然要习惯SO)
还有一个空白的index.html文件。将em全部放在名为mod_submenu
的文件夹中,压缩,安装并配置它!
配置:
结果:
答案 1 :(得分:0)
这可能不是绝对最好的方法,但这是我暂时想到的。
对于父菜单项(第2项),将类型设置为“文本分隔符”。这将阻止它成为一个合适的菜单项,并且很可能(取决于模板)在文本周围包装标签。
然后打开属于该模板的CSS文件并添加以下代码:
span.classname {
display:none;
}
显然,您需要将“classname”更改为任何给予它的类。 Chrome Dev Tools或Firebug将为您提供帮助。