gpt4 book ai didi

symfony - 自定义 KnpMenuBundle

转载 作者:行者123 更新时间:2023-12-03 06:54:17 24 4
gpt4 key购买 nike

如何自定义KNPMenuBundle?

我不知道如何使用 KnpMenuBundle 添加图像或跨度标签。

我只是想要这个:

<ul>
<li>
<img src="{{asset('bundles/mybundle/images/my_image.png')}} /">
<span>My Title</span>
</li>
</ul>

在 MenuBuilder 中,这将以:

$menu->addChild('My Title');

如何将图像添加到<li>中声明?

<小时/>

编辑:简单的方法

实际上有一个简单的方法可以在 bundle 中执行此操作:

1 复制模板 vendor\KnpMenu\src\Knp\Menu\Resources\views\knp_menu.html.twig进入你的Acme\AcmeBundle\Resources\views\Menu\knp_menu.html.twig并按如下方式扩展:

{% extends 'knp_menu.html.twig' %}


2 根据您的需要修改模板。例如,如果您决定每次使用 $menu->addChild('Your Title'); 时添加一个跨度标签,只需在<a></a>之间添加span标签即可:

{% block linkElement %}
<a href="{{ item.uri }}"{{ _self.attributes(item.linkAttributes) }}>
<span>{{ block('label') }}</span>
</a>
{% endblock %}


3 您现在可以在使用菜单时选择自定义布局:

{{ knp_menu_render('main', {'template': 'AcmeBundle:Menu:knp_menu.html.twig'}) }}

最佳答案

CSS 适用于这种情况,但有时您可能需要更显着地添加或更改标记。为此,您可以使用此处定义的自定义渲染器:https://github.com/KnpLabs/KnpMenuBundle/blob/master/Resources/doc/custom_renderer.md

执行此操作的 bundle 示例是 MopaBoostrapBundle我在这里强调了重要的部分。

添加knp_menu.renderer标签的服务定义:

services:
mopa_bootstrap.navbar_renderer:
class: Mopa\Bundle\BootstrapBundle\Navbar\Renderer\NavbarRenderer
arguments: [ @service_container, [] ]
tags:
# The alias is what is used to retrieve the menu
- { name: knp_menu.renderer, alias: navbar }

例如,twig 模板可以这样编写。

<div class="navbar {{ (navbar.hasOption('fixedTop') and  navbar.getOption('fixedTop')) ? 'navbar-fixed-top' : '' }}">
<div class="navbar-inner">
<div class="container{{ (navbar.hasOption('isFluid') and navbar.getOption('isFluid')) ? '-fluid' : '' }}">
<a class="btn btn-navbar" data-toggle="collapse" data-target=".nav-collapse">
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</a>
{% if navbar.hasOption('title') %}<a class="brand" href="{{ path(navbar.getOption('titleRoute')) }}">{{ navbar.getOption('title') }}</a>{% endif %}
<div class="nav-collapse">
{{ navbar.hasMenu('leftmenu') ? knp_menu_render(navbar.getMenu('leftmenu'), {'currentClass': 'active', 'ancestorClass': 'active', 'allow_safe_labels': 'true'}) : '' }}
{% if navbar.hasFormView('searchform') %}
{%- set form_view = navbar.getFormView('searchform') -%}
{%- set form_type = navbar.getFormType('searchform') -%}
{%- set form_attrs = form_view.vars.attr -%}
{% form_theme form_view _self %}
<form class="navbar-search pull-{{ form_attrs.pull|default('left') }}" method="{{ form_attrs.method|default('post') }}" action="{{ path(navbar.getFormRoute('searchform')) }}">
{{ form_widget(form_view) }}
</form>
{% endif %}
{{ navbar.hasMenu('rightmenu') ? knp_menu_render(navbar.getMenu('rightmenu'), {'currentClass': 'active', 'ancestorClass': 'active', 'allow_safe_labels': 'true'}) : '' }}
</div>

</div>
</div>
</div>

关于symfony - 自定义 KnpMenuBundle,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11226963/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com