如何在Drupal 8中将自定义类设置为子菜单?

问题描述 投票:0回答:1

我正在自定义Drupal 8主题的侧边栏菜单上工作。我正在尝试设置一个sidebar__menu - submenu-1,sidebar__menu - submenu-2,sidebar__menu - submenu-3等等,具体取决于子菜单的级别。

到目前为止,我能够将类sidebar__menu添加到第一级和sidebar__menu - 子菜单到所有子菜单。但是,我想添加class sidebar__menu - 子菜单 - (级别的编号),这样我就可以在css上更好地设计和控制侧边栏。

这是我的代码menu.html.twig:

{{ menus.menu_links(items, attributes, 0) }}

{% macro menu_links(items, attributes, menu_level, menu_name) %}
  {% import _self as menus %}
  {%
    set menu_classes = [
      'sidebar__menu' ~ menu_name|clean_class,
    ]
  %}
  {%
    set submenu_classes = [
      'sidebar__menu' ~ menu_name|clean_class ~ '--submenu',
    ]
  %}
  {% if items %}
    {% if menu_level == 0 %}
      <ul{{ attributes.addClass('container mx-auto', menu_classes) }}>
    {% else %}
      <ul {{ attributes.removeClass(menu_classes).addClass(submenu_classes) }}>
    {% endif %}

    {% for item in items %}
     {%
      set classes = [
        'sidebar__item',
        item.is_expanded ? 'sidebar__item--expanded',
        item.is_collapsed ? 'sidebar__item--collapsed',
        item.in_active_trail ? 'sidebar__item--active-trail',
      ]
      %}
      <li{{ item.attributes.addClass(classes) }}>
        {{ link(item.title, item.url) }}
        {% if item.below %}
          {{ menus.menu_links(item.below, attributes, menu_level + 1) }}
        {% endif %}
      </li>
    {% endfor %}
    </ul>
  {% endif %}
{% endmacro %}

任何帮助都会非常感激!

php drupal twig drupal-8
1个回答
0
投票

我找到了答案。首先我们设置类:

{%
set submenu_classes = [
  'sidebar__menu' ~ menu_name|clean_class ~ '--submenu',
  'sidebar__menu--submenu-' ~ (menu_level + 1),
]

%}

然后使用如下逻辑:

{% if menu_level == 0 %}
  <ul{{ attributes.addClass('container mx-auto', menu_classes) }}>
{% else %}
  <ul{{ attributes.removeClass(menu_classes, 'sidebar__menu--submenu-' ~ (menu_level)).addClass(submenu_classes) }}>
{% endif %}
© www.soinside.com 2019 - 2024. All rights reserved.