1

我正在使用SlickNav jQuery 插件,但似乎默认情况下没有设置在模糊或失去焦点时自动关闭菜单,也没有设置它。

我认为这只是一个简单的调用,如下所示:

 <script>
  $(document).ready(function() {
    //close menu on lost focus
    $('.js .slicknav_menu').focusout(function(event){
     $(this).slicknav('close');
    });  
  });
 </script>

但这无济于事。在菜单外单击时如何关闭菜单?

4

2 回答 2

1

我提到了您在问题中提到的网站。尝试了网站中给出的第一个示例。(HTML代码如下)

HTML -

<ul id="menu">
    <li><a class="scroll" href="#features">Features</a></li>
    <li><a class="scroll" href="#usage">Usage Instructions</a></li>
    <li><a class="scroll" href="#examples">Examples</a></li>
    <li><a href="http://github.com">View on Github</a></li>
</ul>

我看到菜单在失去焦点事件时默认没有关闭。下面的代码可以达到同样的效果。

$(document).ready(function() {
    //close menu on lost focus
    $('.slicknav_menu').focusout(function(event){
        $('#menu').slicknav('close'); //Here 'menu' is the id of ul.
    });  
  });
于 2014-10-19T23:42:36.713 回答
0

我用过这样的东西。
这也适用于手机。

$(window).on("touchstart", function(e) {
    var container = $("#menu");
if (!container.is(e.target) // if the target of the click isn't the container...
    && container.has(e.target).length === 0) // ... nor a descendant of the container
{
    $('#menu').slicknav('close');
}
});
于 2016-02-04T14:57:52.540 回答