我有一个带有Bootstrap 3.3.7主题的Drupal 8.6.8网站
我希望在单击外部时关闭导航菜单。我尝试使用代码:
(function ($) {
'use strict';
$(document).click(function (event) {
if (!$(event.target).closest('#navbar-collapse-first').length) {
$('.navbar-collapse-first').collapse('hide');
}
});
}(jQuery));
https://css-tricks.com/dangers-stopping-event-propagation/
它不起作用,如果我在导航菜单外单击,它不会关闭。我希望仅在外部单击才能关闭菜单。除非重新加载页面,否则即使菜单链接也不应关闭菜单。
这是导航菜单按钮的代码:
<div id="block-togglenavigationfirst" class="contextual-region">
<button type="button" class="navbar-toggle-first collapsed" data-toggle="collapse" data-target="#navbar-collapse-first" aria-expanded="false">
<div class="icon-navbar-first">
<span class="fa-layers fa-3x">
<i class="far fa-circle"></i>
<span class="navbar-icon-open">
<i class="fas fa-th-list" data-fa-transform="shrink-8"></i>
</span>
<span class="navbar-icon-close">
<i class="fas fa-times" data-fa-transform="shrink-8"></i>
</span>
</span>
</div>
<div class="icon-navbar-first-alert icon-navbar-first-alert-disable">
<span class="fa-layers fa-3x">
<i class="fas fa-circle"></i>
<span class="navbar-icon-open">
<i class="fas fa-th-list fa-inverse" data-fa-transform="shrink-8"></i>
</span>
<span class="navbar-icon-close">
<i class="fas fa-times fa-inverse" data-fa-transform="shrink-8"></i>
</span>
</span>
</div>
</button>
</div>
这是导航菜单:
<div id="navbar-collapse-first" class="navbar-collapse-first width navbar-collapse-first-fixed-top collapse in" aria-expanded="true" style="">
<div class="region region-navigation-collapsible-first">
<nav role="navigation" aria-labelledby="block-useraccountmenu-menu" id="block-useraccountmenu" class="contextual-region">
<h2 class="sr-only" id="block-useraccountmenu-menu">User account menu</h2>
<ul class="menu menu--account nav navbar-nav navbar-right">
<li class="first last">
<a href="/fr/unmasquerade" title="Retourner sur votre compte utilisateur.">Cesser de se faire passer pour quelqu'un d'autre</a>
</li>
</ul>
</nav>
</div>
</div>
答案 0 :(得分:0)
尝试从w3schools使用此解决方案
https://www.w3schools.com/w3css/tryit.asp?filename=tryw3css_modal_close
答案 1 :(得分:0)
您应该检查点击发生在哪里。如果单击不在导航栏上,则将其切换,否则不要这样做。
您的JavaScript代码将变为:
(function ($) {
'use strict';
$(document).click(function (event) {
if (!($(event.target).is('#navbar-collapse-first *'))
$('.navbar-collapse-first').collapse('hide');
});
}(jQuery));