首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Joomla 2.5中,如何在所有页面上只显示一个根级别项目的子菜单项?

在Joomla 2.5中,如何在所有页面上只显示一个根级别项目的子菜单项?
EN

Stack Overflow用户
提问于 2012-11-29 05:43:11
回答 2查看 7.8K关注 0票数 2

我正在使用Joomla 2.5.8,我想在网站的所有页面上有一个二级菜单,只显示主菜单中根菜单项#2的子菜单项。

代码语言:javascript
复制
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来隐藏我不想要的菜单项,但当我隐藏根菜单项时,我无法获得显示的子菜单项。

我真的不想做单独的菜单,因为如果主菜单有重大的菜单类型变化,我不需要做两次。

有什么想法吗?

EN

回答 2

Stack Overflow用户

发布于 2012-11-29 17:43:07

这是我刚刚制作的一个模块。它呈现您选择的菜单项中的子菜单项。在此处下载该插件:Download

如果你不能下载或者有什么问题,这里有插件文件:

PHP文件(mod_submenu.php):

代码语言:javascript
复制
<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):

代码语言:javascript
复制
<?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>

(请原谅我的格式,我还得习惯)

和一个空白的index.html文件。将em放在一个名为mod_submenu的文件夹中,压缩,安装并配置它!

配置:

结果:

票数 6
EN

Stack Overflow用户

发布于 2012-11-29 06:21:18

这可能不是绝对最好的方法,但这是我目前能想到的全部。

对于父菜单项(项2),将类型设置为“文本分隔符”。这将使其不再是一个正确的菜单项,并且很可能(取决于模板)将标签环绕在文本周围。

然后打开属于该模板的CSS文件,并添加以下代码:

代码语言:javascript
复制
span.classname {
    display:none;
}

显然,您需要将"classname"更改为指定的任何类。Chrome Dev Tools或Firebug将为您提供帮助。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13614942

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档