5

我想我的视图代码如下所示:

<li>
    <a href="path/to/action">
            <i class="icon-class"></i>
            <span class="title">Title</span>
    </a>
</li>

我通过 Menu Builder 创建菜单元素:

class Builder extends ContainerAware
{
    public function adminMenu(FactoryInterface $factory, array $options)
    {
        $menu = $factory->createItem('root');

        $menu->addChild('Dashboard', array(
            'route' => 'admin_dashboard',
        ));

        return $menu;
    }
}

我用以下代码(knp_menu.html.twig)覆盖了视图:

{% block linkElement %}
    {% import _self as knp_menu %}
    <a href="{{ item.uri }}"{{ knp_menu.attributes(item.linkAttributes) }}>
        <i class="icon-class"></i>
        <span class="title">{{ block('label') }}</span>
    </a>
{% endblock %}

如何<i>在 Builder 类中将图标类名称的值传递给方法 adminMenu() 中的元素?最简单的方法是什么?

4

3 回答 3

9

你可以添加任何你想要的属性

$menu->addChild('Dashboard', array(
    'route' => 'admin_dashboard',
))->setAttribute('icon', 'icon-class');

然后

{{ item.attribute('icon') }}
于 2015-01-02T20:04:30.863 回答
4

我建议使用 ofextras而不是attributes,因为attributes它用于呈现li元素的属性。

$menu->addChild('Dashboard', array(
    'uri' => '#',
))->setAttribute('icon', 'icon-class');

{{ item.attribute('icon') }}

可能会呈现为:

<li icon="icon-class"><a href="#"><i class="fa fa-icon-class" aria-hidden="true"></i> Dashboard</a></li>

然而:

$menu->addChild('Dashboard', array(
    'uri' => '#',
))->setExtra('icon', 'icon-class');

{{ item.extra('icon') }}

可能只会呈现为:

<li><a href="#"><i class="fa fa-icon-class" aria-hidden="true"></i> Dashboard</a></li>

另请参阅此答案:https ://stackoverflow.com/a/19095287/2106834 。

于 2016-10-31T09:45:10.313 回答
0

简单地:

$menu->addChild('Home', ['route' => 'home_page'])
        ->setAttribute('icon', 'fa fa-home');
于 2015-01-02T20:51:00.637 回答