39

以下简单代码:

<li><a href="{{ path('_list') }}">List</a></li>

class="active"如果当前页面与_list路线匹配,是否有一种简单的方法来添加?

使用 symfony2 和 twig 的最新 PR-Release 作为模板引擎

4

10 回答 10

102

Twig 允许使用条件,并且 Request 对象在整个应用程序中都可用。如果您包含模板,则要获取要使用的路线:

app.request.attributes.get('_route')

如果您使用的是渲染功能,您想使用:

app.request.attributes.get('_internal')

有了这个,你应该能够使用:

class="{% if app.request.attributes.get('_route') == '_list' %}active{% endif %}"

或更短:

class="{{ app.request.get('_route') == '_list' ? 'active' }}"
于 2011-04-18T14:19:30.197 回答
23

有时您不想对路线进行精确匹配。对于这些情况,您可以使用 twig 的“开始于”条件逻辑。

例如,假设您正在处理书籍。您有以下路线:book、book_show、book_new、book_edit。您希望在任何这些情况下突出显示导航项 Book。这段代码可以做到这一点。

<a class="{% if app.request.attributes.get('_route') starts with 'book' %}active{% endif %}">Books</a>
<a class="{% if app.request.attributes.get('_route') starts with 'author' %}active{% endif %}">Authors</a>

这个例子至少适用于 Symfony 2.3.x

于 2013-10-21T22:16:17.597 回答
23

最短版本:

{% set route = app.request.get('_route') %}

 <li class="{{ route starts with 'post' ? 'open' }}"></li>
 <li class="{{ route starts with 'category' ? 'open' }}"></li>

有时有用:

{% set route = app.request.get('_route') %}

<li class="{{ 'post' in route ? 'open' }}"></li>
<li class="{{ 'category' in route ? 'open' }}"></li>
于 2016-01-14T10:08:37.183 回答
10

使用三元运算符:

    {% set route = app.request.attributes.get('_route') %}
    <ul class="nav navbar-nav">
        <li {{ route ==  'profile_index' ? 'class="active"' }}><a href="{{ path('profile_index') }}"><i class="icon-profile position-left"></i> My Profile</a></li>
        <li {{ route ==  'influencers_index' ? 'class="active"'}}><a href="{{ path('influencers_index') }}"><i class="icon-crown position-left"></i> Influencers</a></li>
        <li {{ route ==  'task_manager_index' ? 'class="active"'}}><a href="{{ path('task_manager_index') }}"><i class="icon-alarm-check position-left"></i> Task Manager</a></li>
    </ul>
于 2015-11-18T23:01:44.140 回答
6

这是用 symfony 3.4 完成的,但可能类似的东西可以用 SF2 完成。

src\AppBundle\Twig\AppExtension.php

<?php

namespace AppBundle\Twig;

use Symfony\Component\HttpFoundation\RequestStack;

class AppExtension extends \Twig_Extension
{
    private $requestStack;

    public function __construct(RequestStack $requestStack)
    {
        $this->requestStack = $requestStack;
    }

    public function getFunctions()
    {
        return [
            new \Twig_SimpleFunction('activeMenu', [$this, 'activeMenu'])
        ];
    }

    /**
     * Pass route names. If one of route names matches current route, this function returns
     * 'active'
     * @param array $routesToCheck
     * @return string
     */
    public function activeMenu(array $routesToCheck)
    {
        $currentRoute = $this->requestStack->getCurrentRequest()->get('_route');

        foreach ($routesToCheck as $routeToCheck) {
            if ($routeToCheck == $currentRoute) {
                return 'active';
            }
        }

        return '';
    }
}

将此添加到 services.yml

services:
    #... some other services
    AppBundle\Twig\AppExtension:
        arguments: ["@request_stack"]

用法:

<ul class="nav navbar-nav">
    <li class="{{ activeMenu(['form', 'edit_form']) }}"><a href="{{ path('form') }}">Form</a></li>
    <li class="{{ activeMenu(['list']) }}"><a href="{{ path('list') }}">List</a></li>
</ul>
于 2018-01-07T11:31:04.553 回答
3

我发现了一个非常好的 Bundle 可以自动处理所有这些东西:

https://github.com/KnpLabs/KnpMenuBundle

于 2011-04-19T20:45:57.937 回答
1

SF2.2

{{ dump(app.request.server.get('PATH_INFO')) }}
于 2013-05-03T18:17:50.310 回答
1

Symfony2.3,在 Twig 中,试试这个来获取 uri:

{{ dump(app.request.server.get("REQUEST_URI")) }}
于 2013-09-16T06:12:12.317 回答
-1

我就是这样做的(使用 Symfony 2.6)

<li {% if app.request.get('_route') == '_homepage' %} class="active" {% endif %}><a href="{{ path('_homepage') }}">Student</a></li>

'_homepage'是您的捆绑包中的路线名称,路线routing.yml如下所示

_homepage:
    path:     /
    defaults: { _controller: CoreBundle:Default:index }
于 2015-06-08T11:22:12.367 回答
-4

class="class_name {% if loop.index0 == 0 %}CLASSNAME{% endif %}"

于 2017-03-03T12:47:57.880 回答