我对新版本的jQuery mmenu有一个问题。我已经看到了与MMENU较旧版本一起使用的解决方案,但也没有使用该版本,我也找不到文档中的某些内容。
我有一个普通菜单(设备宽度大于1024px(:
<nav id="menu">
<ul class="nav-firstlvl">
<li>
<a href="/documentation/" title="Documentation">Documentation</a>
</li>
<li class="act">
<a href="/module/" title="Module">Module</a>
<ul class="nav-secondlvl">
<li class="act">
<a href="/module/subpage/" title="Subpage">Subpage</a>
</li>
</ul>
</li>
<li>
<a href="/organisation/" title="Organisation">Organisation</a>
<ul class="nav-secondlvl">
<li>
<a href="/organisation/subpage/" title="Subpage">Subpage</a>
</li>
</ul>
</li>
<li>
<a href="/contact/" title="Contact">Contact</a>
</li>
</ul>
</nav>
由mmenu克隆:
var $menu = jQuery("#menu").mmenu({
"extensions": [
"position-right"
]
}, {
clone:true
}
);
所有工作都很好。我的问题是,如果用户在子菜单的页面上(我的示例的" subpage"一页(,我想在子菜单上打开菜单。我试图将" MM-OPENED"级添加到一个活跃的子类列表项目的列表中,但什么也没发生。菜单在第一级打开。然后,我意识到,与较旧的mmenu-version相比,新版本有不同的类别和不同的结构。
<nav id="mm-menu" class="mm-menu mm-menu_offcanvas mm-menu_position-right" aria-hidden="true">
<div class="mm-panels">
<div id="mm-0" class="mm-panel mm-panel_has-navbar mm-panel_opened">
<div class="mm-navbar">
<a class="mm-navbar__title">Menu</a>
</div>
<ul class="nav-firstlvl mm-listview">
<li class="mm-listitem">
<a href="/documentation/" title="Documentation">Documentation</a>
</li>
<li class="act mm-listitem">
<a class="mm-btn_next" href="#mm-1">
<span class="mm-sronly">Open submenu (Module)</span>
</a>
<a href="/module/" title="Module">Module</a>
</li>
<li class="mm-listitem">
<a class="mm-btn_next" href="#mm-2">
<span class="mm-sronly">Open submenu (Organisation)</span>
</a>
<a href="/organisation/" title="Organisation">Organisation</a>
</li>
<li class="mm-listitem">
<a href="/contact/" title="Contact">Contact</a>
</li>
</ul>
</div>
<div id="mm-1" class="mm-panel mm-hidden mm-panel_has-navbar" aria-hidden="true">
<div class="mm-navbar">
<a class="mm-btn mm-btn_prev mm-navbar__btn" href="#mm-0" aria-owns="mm-0" aria-haspopup="true">
<span class="mm-sronly">Close submenu</span>
</a>
<a class="mm-navbar__title" href="#mm-0">Module</a>
</div>
<ul class="nav-secondlvl mm-listview">
<li class="act mm-listitem">
<a href="/module/subpage/" title="Subpage">Subpage</a>
</li>
</ul>
</div>
<div id="mm-2" class="mm-panel mm-hidden mm-panel_has-navbar" aria-hidden="true">
<div class="mm-navbar">
<a class="mm-btn mm-btn_prev mm-navbar__btn" href="#mm-0" aria-owns="mm-0" aria-haspopup="true">
<span class="mm-sronly">Close submenu</span>
</a>
<a class="mm-navbar__title" href="#mm-0">Organisation</a>
</div>
<ul class="nav-secondlvl mm-listview">
<li class="mm-listitem">
<a href="/organisation/subpage/" title="Subpage">Subpage</a>
</li>
</ul>
</div>
</div>
</nav>
当然我可以添加和删除JQuery的几个类?我无法想象他们会从如此轻松的事情变成相当复杂的事情...
任何帮助,指示,甚至是我显然找不到的文档部分的链接,将不胜感激。谢谢
编辑
我刚刚意识到,克隆时,MMENU NAV并未从普通子菜单上列出列表项目上的ACT类。也许这是这里的问题...或者这甚至可能是一个错误?
好吧...我在配置中忘记了一些东西(我在文档教程中找到了...(
我必须更改mmenu的初始化配置:
var $menu = jQuery("#menu").mmenu({
"extensions": [
"position-right"
]
}, {
clone:true,
classNames: { // This part was missing...
selected: "act"
}
}
);