3

我目前正在使用 Zend Framework 1.12.3 创建我的新网站,我看到了一些我讨厌 Zend Navigation 的地方:

当子路由处于活动状态时(例如:博客单篇文章 route blog-post),它不会将父页面(blog在这种情况下为路由)标记为活动。

这是我的代码:(navigation.xml)

<blog>
    <label>BLOG</label>
    <route>blog</route>
    <title>BLOG_TITLE</title>
    <pages>
        <blog-post>
            <route>blog-post</route>
            <visible>false</visible>
        </blog-article>
        <blog-category>
            <route>blog-category</route>
            <visible>false</visible>
        </blog-category>
    </pages>
</blog>

blog很明显,如果像这样的子路由处于活动状态,我会将页面标记为活动blog-post状态。不幸的是,如果不使用子页面(我不想要),它就不会这样做。因此,如果有一种方法可以将路线名称blog和所有以blog(例如:、、、blog-post)开头的路线标记为活动blog-categoryblog-author那将非常有用!

我不想为此使用子页面,因为我的菜单部分呈现了一个空下拉列表(Twitter Bootstrap)。自己看:

Zend 中的空下拉菜单

4

2 回答 2

5

我知道它已经得到了回答,但我找到了不同的解决方案,因为 Marshall 发布的一个对我不起作用。我想这是因为我没有在菜单中使用动作/控制器,而是使用路由

我的菜单条目如下所示:

array(
    'label' => 'cms-nav_users',
    'access_module' => 'user',
    'resource' => 'user_admin',
    'route' => 'admin_user',
    'pages' => array(
        array(
            'label' => 'cms-nav_companies',
            'access_module' => 'user',
            'route' => 'company_admin',
            'resource' => 'company_admin',
        ),
        array(
            'label' => 'cms-nav_users-list',
            'access_module' => 'company',
            'route' => 'admin_user',
            'resource' => 'user_admin',
        ),
    ),
),

我想出了一个基于我自己的菜单模板(部分)的解决方案。基本上有一个 foreach 循环,它检查是否有任何子页面处于活动状态,如果有一个 - 将父页面标记为活动,它看起来像这样:

$active = false;

if (!empty($page->pages))
{
    foreach ($page->pages as $subpage) 
    {
        if ($subpage->isActive()) $active = true;
    }
}

$html[] = ($active) ?  'class="active"' : '';

希望它可以帮助某人:)

更新

实际上我发现您可以使用 Zend Framework 自己的 isActive()true参数,如源代码所示:

Zend_Navigation_Page_Mvc::isActive($recursive = false)

两种方式都可以,但这种方式更合适。

于 2013-07-03T06:34:14.230 回答
2

从文档中:

array(
    'label' => 'Page 2',
    'controller' => 'page2',
    'pages' => array(
        array(
            'label' => 'Page 2.1',
            'action' => 'page2_1',
            'controller' => 'page2',
            'class' => 'special-one',
            'title' => 'This element has a special class',
            'active' => true
        ),
        array(
            'label' => 'Page 2.2',
            'action' => 'page2_2',
            'controller' => 'page2',
            'class' => 'special-two',
            'title' => 'This element has a special class too'
        )
    )
),

如您所见,父菜单项没有分配给它的操作,但是父菜单项和子菜单项共享同一个控制器。这就是您可以在子页面的父页面上拥有活动状态的方式。

于 2013-04-11T02:37:45.490 回答