我正在尝试在 WordPress 多站点安装上设置一个持久的网络范围菜单。这是使用网络范围的菜单插件实现的,并且效果很好。唯一的问题是样式,因为自动“当前菜单项”类仅在主博客上嵌入到适当的菜单链接中。
因此,我研究了 .addClass() 函数,以根据当前 URL 将类添加到菜单项中,这就是我迄今为止提出的。请记住,我也试图突出显示父项,这就是我还使用 .parentsUntil() 类的原因。
这是我的网络设置(每个域对应一个 WordPress 实例):
domain.com
blog1.domain.com
blog1.domain.com
blog1.domain.com
这是我的 jQuery 代码:
jQuery(function() {
jQuery('#megaUber ul li').removeClass('activeMenu');
var href = window.location.href;
if (href.indexOf('http://domain.com) != -1) {
jQuery('#megaUber a').parentsUntil('.ss-nav-menu-item-depth-0').addClass('activeMenu');
} else if (href.indexOf("http://blog1.domain.com") != -1) {
jQuery('#megaUber li a[href="'+href+'"]').parentsUntil('.ss-nav-menu-item-depth-0').addClass('activeMenu');
} else if (href.indexOf("http://blog2.domain.com") != -1) {
jQuery('#megaUber li a[href="'+href+'"]').parentsUntil('.ss-nav-menu-item-depth-0').addClass('activeMenu');
} else if (href.indexOf("http://blog3.domain.com") != -1) {
jQuery('#megaUber li a[href="'+href+'"]').parentsUntil('.ss-nav-menu-item-depth-0').addClass('activeMenu');
}
});
HTML 菜单标记
<div id="megaMenu">
<ul id="megaUber" class="megaMenu" data-theme-location="primary">
<li id="menu-item-20" class="nav-cgroupe menu-item menu-item-type-post_type menu-item-object-page current-page-ancestor current-menu-ancestor current-menu-parent current-page-parent current_page_parent current_page_ancestor mega-with-sub ss-nav-menu-item-1 ss-nav-menu-item-depth-0 ss-nav-menu-mega ss-nav-menu-mega-alignCenter ss-nav-menu-with-desc">
<a href="http://domain.com">domain.com</a>
<ul class="sub-menu sub-menu-1" style="display: none;">
<li id="menu-item-25" class="menu-item menu-item-type-post_type menu-item-object-page ss-nav-menu-item-depth-1">
<a href="http://domain.com/link1">Link1</a>
</li>
<li id="menu-item-24" class="menu-item menu-item-type-post_type menu-item-object-page ss-nav-menu-item-depth-1">
<a href="http://domain.com/link2">Link2</a>
</li>
<li id="menu-item-23" class="menu-item menu-item-type-post_type menu-item-object-page ss-nav-menu-item-depth-1">
<a href="http://domain.com/link3">Link3</a>
</li>
</ul>
</li>
<li id="menu-item-26" class="nav-cconseil menu-item menu-item-type-custom menu-item-object-custom mega-with-sub ss-nav-menu-item-2 ss-nav-menu-item-depth-0 ss-nav-menu-mega ss-nav-menu-mega-alignCenter ss-nav-menu-with-desc">
<a href="http://blog1.domain.com">blog1.domain.com</a>
<ul class="sub-menu sub-menu-1" style="display: none;">
<li id="menu-item-53" class="menu-item menu-item-type-custom menu-item-object-custom ss-nav-menu-item-depth-1">
<a href="http://blog1.domain.com/link1">Link1</a>
</li>
<li id="menu-item-54" class="menu-item menu-item-type-custom menu-item-object-custom ss-nav-menu-item-depth-1">
<a href="http://blog1.domain.com/link2">Link2</a>
</li>
<li id="menu-item-55" class="menu-item menu-item-type-custom menu-item-object-custom ss-nav-menu-item-depth-1">
<a href="http://blog1.domain.com/link3">Link3</a>
</li>
</ul>
</li>
</ul>
</div>
我已经扭曲了很多不同的方式,但无法做到正确......有人知道如何实现这一目标吗?
谢谢你,C。