2010-09-29 67 views
0

我想写我自己的菜单风格,但我宁愿在模板中做它,而不是让我自己的菜单scomp。如何从Zotonic模板访问菜单模型?

我基本上希望能够做一些事情,如:

{% if m.menu %} 
    <ul> 
    {% for top_level_id in m.menu %} 
    {% with m.rsc[top_level_id] as top_level %} 
     <li><a href="{{ top_level.page_url }}">{{ top_level.title }}</a> 
     {% if top_level.menu %} 
     <ul> 
     {% for mid_level_id in top_level.menu %} 
      {% with m.rsc[mid_level_id] as mid_level %} 
      <li><a href="{{ midlevel.page_url }}">{{ mid_level.title }}</a></li> 
      {% endwith %} 
     {% endfor %} 
     </ul> 
     {% endif %} 
     </li> 
    {% endwith %} 
    {% endfor %} 
    </ul> 
{% endif %} 

如何从一个Zotonic模板进入菜单模式?

回答

1

添加到我的上一个答案。标准_menu.tpl收到包含所有菜单项的列表。此列表是完整菜单的深度优先树行程的结果。每一个菜单是

{MenuRscId, DepthOfMenu, NrInSubMenu, HasSubMenuFlag} 

当顶级菜单具有深度为1,并在菜单的第一个菜单项纪录的1

所有菜单项NR当前用户不是允许看到被过滤掉。

默认模板的代码:

<ul id="{{ id_prefix }}navigation" class="clearfix at-menu do_superfish"> 
{% for mid,depth,nr,has_sub in menu %} 
    {% if not mid %}{% if depth > 1 %}</ul></li>{% endif %} 
    {% else %} 
    {% if nr == 1 and not forloop.first %}<ul{% if mid|member:path %} class="onpath"{% endif %}>{% endif %} 
    <li id="{{ id_prefix }}nav-item-{{nr}}" 
     class="{% if is_first %}first {% endif %}{% if is_last %}last{% endif %}"> 
     <a href="{{ m.rsc[mid].page_url }}" 
      class="{{ m.rsc[mid].name }}{% if mid == id %} current{% else %}{% if mid|member:path %} onpath{% endif %}{% endif %}">{{ m.rsc[mid].short_title|default:m.rsc[mid].title }}</a> 
    {% if not has_sub %}</li>{% endif %} 
{% endif %} 
{% endfor %} 
{% if forloop.last %}{% include "_menu_extra.tpl" %}{% endif %} 
</ul> 
1

(即将发布的)0.5版本和Zotonic的提示使用模板来显示菜单。检查mod_menu/templates/_menu.tpl

该模板由menu scomp调用。