我有一个有Django CMS 3.5.1和Django 1.11.11的网站,它有一个用CMS构建的菜单。其中一个页面是一个apphooked事件列表。当我点击事件详细信息时,菜单会丢失其活动类。
这是我的菜单:
{% for child in children %}
<li class="js-submenuParent {% if child.selected or child.ancestor %}active{% endif %}">
<a href="{% if child.children %}javascript:void(0);{% else %}{{ child.attr.redirect_url|default:child.get_absolute_url }}{% endif %}" class="{% if child.children %}submenu-btn js-openSubmenu{% endif %}">{{ child.get_menu_title }}</a>
{% if child.children %}
<ul class="submenu js-submenu">
{% show_menu from_level to_level extra_inactive extra_active template "" "" child %}
</ul>
{% endif %}
</li>
{% endfor %}
我认为child.ancestor
可以解决问题(甚至child.selected
,因为我似乎可以使用{% page_attribute "page_title" %}
访问父级的标题,但事实并非如此。我是否必须制作custom apphook menu才能做到这一点,还是有更简单的解决方案?
答案 0 :(得分:1)
您附加应用程序的页面是菜单系统知道的最后一点,直到您为应用程序集成菜单。
添加菜单可让您的应用网址通过您的网址NavigationNode(title, url, id)
对象与菜单应用集成。
因此,如果您有详细信息视图,则可以附加一个简单的菜单;
from menus.base import NavigationNode
from menus.menu_pool import menu_pool
from django.utils.translation import ugettext_lazy as _
from cms.menu_bases import CMSAttachMenu
class EventMenu(CMSAttachMenu):
name = _("event menu")
def get_nodes(self, request):
nodes = []
n = NavigationNode(_('detail page'), "/detail", 1)
nodes.append(n)
return nodes
menu_pool.register_menu(EventMenu)
关于这方面的文件在这里; http://docs.django-cms.org/en/latest/how_to/menus.html#integration-attach-menus
基于以上所述,您还可以根据您通过一些调查找到的列表/查询集等生成节点;
def get_nodes(self, request):
nodes = []
for event in Event.objects.published():
n = NavigationNode(
event.title, # title
event.get_absolute_url(), # url
'id_{slug}'.format(slug=event.slug), # unique ID for node
visible=False
)
nodes.append(n)
return nodes
答案 1 :(得分:1)
这是3.5.x和3.4.x菜单增强中引入的回归。
它已修复,将在3.5.3和3.4.7
上发布