单击外部以关闭下拉头像菜单

时间:2019-11-30 00:32:41

标签: javascript css drop-down-menu menu avatar

我有此头像下拉菜单,您必须单击该头像以关闭菜单,但我希望能够单击页面上的任意位置以关闭菜单。任何帮助将不胜感激。

下面是html和javasript

<div class="user-menu-wrap">
            <a  class="mini-photo-wrapper" href="page.html" onclick="return false" style="cursor:pointer;"><img src="/images/default_avatar.png" /></a>

  <div class="menu-container">
    <ul class="user-menu" style="list-style:none;">
      <li class="user-menu__item"><a class="user-menu-link" href="/member.php">Profile</a></li>
      <li class="user-menu__item"><a class="user-menu-link" href="/private.php">Messages</a></li>
      <li class="user-menu__item"><a class="user-menu-link" href="/friends">Friends</a></li>
      <li class="user-menu__item"><a class="user-menu-link" href="/view-alerts">Alerts</a></li>

    </ul>
  </div>

    document.querySelector('.mini-photo-wrapper').addEventListener('click', function() {
  document.querySelector('.menu-container').classList.toggle('active');
});

1 个答案:

答案 0 :(得分:1)

window.onload = function(){
  var divToHide = document.getElementById('divToHide');
  document.onclick = function(e){
    if(e.target.id !== 'divToHide'){
      document.querySelector('.menu-container').classList.remove('active');
    }
  };
};

我几乎将其复制粘贴了。如果页面上只有一个项目,则像本例一样,优先选择id而不是class。